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(54) Fast building of masks for use in incremental printing 

(57) A program with complete conditions for a usa- 
ble mask yields a unitary mask, each try. One mask pat- 
tern is used throughout an image, but may be "tiled". 
Preferably the program, for given mask position, 
expresses favorability of several candidate pass num- 
bers as a "neighborhood constraint" in the form of a 
weight; distills the weights into one weight for each pass 
number; based on that, chooses a number for the posi- 
tion; and iterates for all positions. Many preferences are 
very useful, e.g. automatically balancing randomness 
vs. determinism, and several generalized relative nota- 
tions. Another invention facet uses an input text file of 
mask constraints; a program reads constraints from the 
file, applies them, forms a mask and stores/uses it. 
Another reprocesses a mask for best image quality, fix- 
ing its own imperfections of first-round mask forming. 



CM 
< 

CO 
CM 

in 

o 
o> 



Q. 

LU 



Printed by Xerox (UK) Business Services 
2.16.7/3.6 



BNSDOCID: <EP 0990528A2_I_> 



EP 0 990 528 A2 



Description 

RPI ATFD PATENT DOCUMENTS 

s r0001l Eiaht closely related documents are other, coowned and copending U. S. utility-patent applications: serials 
08/810 053 08/810.747. 08/810.753. 08/81 1 .788. and 08/81 1 .875 all filed March 4, 1997. of Josep Maria Serra et air 
08/814949'filed March 10. 1997. of Michael Chang et at. ; 08/957.853 filed October 27. 1997. of Amir Doron et a/.; and 
08/789 859 filed January 28. 1997. of Irene Heitsch. These eight applications have respectively issued as U.S^ Patents 

5 ' 0 n , 200_; 5 on . 200_; 5 

10 nn . 200_; 5 . on . 200_; 5 . on 

on s op _ ; 5 . on - 200_; 5 . on 

" ' 200_ and 5 on . 200_. Two other closely related docu- 

ments are coowned utility Went applications filed in the United States Patent and Trademark Office substantially con- 
temooraneously with this document. One is in the names of Joan Manel Garcia sLaL and identified as attorney docket 
S^Sh88. and entitled "MASKS ON DEMAND FOR USE IN INCREMENTAL PRINTING" - and subse- 
quently assigned utility-patent application serial 08/ . and issued as U S Patent 5 — •— — ° n 

200_ The other such document is in the names of Joan Manel Garcia §LaL and identified as 
attorney docket 60980042H89, and entitled "OPTIMAL-SIZE AND NOZZLE -MODULATED MASKS FOR USE IN 

INCREMENTAL PRINTING"— and subsequently assigned utility-patent application serial 08/ ^ and 

SD issued as U. S. Patent 5 . on , 200_. All the above ten documents are hereby 

incorporated by reference in their entireties into this document. 
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F'FI n <1 p THE INVENTION 

25 [0002] This invention relates generally to machines and procedures for incremental printing or copying of text or 
graphics on printing media such as paper, transparency stock, or other glossy media; and more particularly to a 
machine and method that construct - under direct computer control - text or images from individual colorantspots 
created on a printing medium, in a two-dimensional pixel array. For purposes of this document^ the phrases mere- 
mental printing" and "incremental printer" I mean to encompass all printers and copiers that perform computer-control- 

30 led construction of images by small increments. _.„_,.„_ . , ■- u i , 

[00031 The invention advances the art of both printmasks and halftoning or so-called dither masks. For the sake of 
simplicity the invention will be described primarily with respect to printmasks. but it is to be understood that in many 
cases this term equivalent^ encompasses halftoning or dither masks. Without further elaboration, a person of common 
skill in the art will readily understand when such equivalency is present and when it is not. 

35 [00041 The invention employs printmode and dithering techniques to optimize image quality vs. operating time and 
dala-storage costs, and is particularly but not exclusively beneficial in scanning thermal-inkjet machmes and methods. 
For def initeness the discussion in this document will refer to inkdrops. coalescence and other features and phenomena 
associated with Inkjet printers; however, it is to be understood that equivalent characteristics of other printer types are 
encompassed within that discussion. 

RAP.KnROUND OFT HF INVENTION 

[0005] Inkjet printere. and certain other types of incremental printers, are inherently capable of a very limited number 
of tonal levels. To achieve a moderate range of tonal variations in such printers, halftoning or dither masks are used to 
transform or "render" input variations in intensity in the form of spatially varying densities. 

[0006] The eye integrates the spatial variations to. in effect, reconstruct a semblance of continuous-tone capability. 
The halftoning process, in incremental printers, sometimes employs masks known as dither masks or halftone masks 
and the preparation of these masks is a matter of importance in terms of preparation time, data storage, and final output 

[0007] To achieve vivid colors in inkjet printing with aqueous inks, and to substantially fill the white space between 
addressable pixel locations, ample quantities of ink must be deposited. Doing so. however, requires subsequent 
removal of the water base — by evaporation (and. for some printing media, absorption) — and this drying step can be 

unduly time consuming. .. . „_ 

[0008] In addition, if a large amount of ink is put down all at substantially the same time, within each section of an 
image related adverse bulk-colorant effects arise. These include so-called "coalescence" and "bleed" of one color into 
another (particularly noticeable at color boundaries that should be sharp), "blocking" or offset of colorant in one pnnted 
image onto the back of an adjacent sheet with consequent sticking of the two sheets together (or of one sheet to pieces 
of the apparatus or to slipcovers used to protect the imaged sheet), and "cockle" or puckering of the printing medium. 



40 



45 



50 



2 



BNSDOCID' <EP 099O528A2 I > 



EP 0 990 528 A2 

Various techniques, discussed below, are known for use together to moderate these adverse drying-time effects and 
bulk- or gross-colorant effects. 

(a) Prior heat-application techniques — Among these techniques is heating the inked medium to accelerate evap- 
s oration of the water base or carrier. Heating, however, has limitations of its own; and in turn creates other difficulties 

due to heat-induced deformation of the printing medium. 

Glossy stock warps severely in response to heat, and transparencies too can tolerate somewhat less heating 
than ordinary paper. Accordingly, heating has provided only limited improvement of drying characteristics for these 
plastic media. 

™ As to paper, the application of heat and ink causes dimensional changes that affect the quality of the image or 

graphic. Specifically, it has been found preferable to precondition the paper by application of heat before contact of 
the ink; if preheating is not provided, so-called "end-of-page handoff" quality defects occur —this defect takes the 
form of a straight image-discontinuity band formed across the bottom of each page when the page bottom is 
released. 

is Preheating, however, causes loss of moisture content and resultant shrinking of the paper fibers. To maintain 

the paper dimensions under these circumstances the paper may be held in tension, but this too induces still other 
types of image defects requiring yet further innovation to overcome them. 

(b) Printmod e techniques — Another useful technique is laying down in each pass of the pen only a fraction of the 
total ink required in each section of the image — so that any areas left white in each pass are filled in by one or 

20 more later passes. This tends to control bleed, blocking and cockle by reducing the amount of liquid that is all on 
the page at any given time, and also may facilitate shortening of drying time. 

The specific partial-inking pattern employed in each pass, and the way in which these different patterns add up 
to a single fully inked image, is known as a "print mode". Heretofore most efforts in design of print modes have 
focused upon difficulties introduced by regularity or repetition of patterns previously regarded as inherent in print- 

25 mode techniques. 

For example, some print modes such as square or rectangular checkerboard-like patterns tend to create objec- 
tionable moire effects when frequencies or harmonics generated within the patterns are close to the frequencies or 
harmonics of interacting subsystems. Such interfering frequencies may arise in dithering subsystems sometimes 
used to help control the paper advance or the pen speed. 
so More recently, however, attention has turned to use of random or more-properly "randomized" patterns. These 

are introduced in the coowned patent documents listed earlier and will be discussed in greater detail shortly. 

(c) Known technology of printmodes: general introduction — The pattern used in printing each nozzle section is 
known as the "printmode mask" or "printmask". The term "printmode" is more general, usually encompassing a 
description of a mask, the number of passes required to reach full density and the number of drops per pixel def in- 

35 ing lull density". 

One particularly simple way to divide up a desired amount of ink into more than one pen pass is the checker- 
board pattern mentioned above: every other pixel location is printed on one pass, and then the blanks are filled in 
on the next pass. This pioneering strategy was quickly recognized as inadequate for highly demanding competitive 
modern printers because of ink coalescence along diagonals, inability to correct moire phenomena, and also the 

40 appearance of so-called "banding" or evident boundaries between abutting ink swaths. 

To reduce such horizontal banding problems (and sometimes minimize the moire patterns) discussed above, 
a print mode may be constructed so that the paper advances between each initial-swath scan of the pen and the 
corresponding fill-swath scan or scans. In fact this can be done in such a way that each pen scan functions in part 
as an initial-swath scan (for one portion of the printing medium) and in part as a fill-swath scan. 

45 This technique tends to distribute rather than accumulate print-mechanism error that is impossible or expen- 

sive to reduce. The result is to minimize the conspicuousness of —or, in simpler terms, to hide — the error at min- 
imal cost. 

All of these strategies are now well known and have been elaborated to a very great extent, including the use 
of space- and sweep-rotated printmode masks, autorotating printmode masks (in which rotation occurs even 
so though the pen pattern is consistent over the whole pen array and is never changed between passes), and steeply 
angled, separated mask-pattern lines. An extensive discussion of such methods appears in U. S. Patent 5,677,716 
of Cleveland. Analogous problems and solutions are known in regard to dither masks as well. 

(d) Nozzle-variation effects — Different groups or areas of nozzles in a pen have different effects on image quality. 
Only a few techniques have been introduced for adapting printer control mechanisms to accommodate or even 

55 exploit such variations. 

European Patent 730,967 of Nicoloff et al. explains that overlap between two different-color inks, during a sin- 
gle scan, can be prevented by operating only a section of each nozzle array (I e.. pen) during such a single scan. 
It appears that the selection of the section to be operated, in Nicoloff, is consistent. 
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United Kingdom Patent 2.302,065 of Nobel et_ai deals exclusively with text printing. It teaches variation of 
printhead alignment with respect to the lines of text, from page to page or at other intervals -so that top and bot- 
tom nozzles can be used about equally and also causes wear of middle nozzles to be more uniform. 

As pens are fabricated by automatic techniques that continually increase in efficiency and speed new kinds of 
s nozzle variations continue to appear. Further development in the area of dealing with such variations is therefore 
needed. ~ - - 

( t } ~ PfOfiPgatiSD of banding problems -Heretofore, however, all these many ingenious stratagems have fallen 
short of eliminating banding. This is particularly true in the midtone range where small repetitive patterns even sub- 
tle patterns, often become very objectionably conspicuous. Such difficulties are known in regard to both dither 
10 masks and printmasks. 

Particularly as to the latter, the current generation of efforts includes the work outlined in at least the Serra and 
Chang documents to eliminate such problems by "randomizing" of masks. L& building masks by pseudorandom 
processes. Generally speaking, both these groups of workers teach the possibility of operating a randomized 
mask-building process in real time, in a printer -but rejest that possibility, teaching away from it in favor of human 
inspection of computer-generated candidate masks, for best esthetics of printed results. 

Chang suggests a balance between ink-media artifacts (which he associates with such esthetic choice by a 
live person) and mechanical artifacts (which he associates with randomization as a curative). Chang accordingly 
teaches that the inspection step is essential at least for the present. 

The efforts of both Serra and Chang are distinct and important improvements over the prior art With respect 
to their largest objectives, however, these efforts have foundered on the persistence of conspicuous and distinctive 
— even though substantially random — patterns that repeat dozens of times across a typical image 

In hindsight, the reason behind such persistence is clear. Operation of printers using these newest rand- 
omized masks amounts to a superposition of a repeating mask pattern with a constant pattern of pen nozzle mis- 
directions, weak or failed nozzles, and other flaws of static character. The system convolves the same mask 
25 patterns with the same nozzles over and over. 

The resulting granularity is generally far larger than individual pixels or inkdrops. Although some shapes can 
be reduced for a particular image by tinkering with mask patterns, this approach too is typically prohibitive with 
common images — which are ordinarily very complex 

«• ,., O, f 0U u rSe * ' S " 0t intended here to undulv criticj ze the contributions of these skillful and talented workers in this 
field, who have produced important and useful advances. Yet that effort leaves room for improvement 

Indeed, from the perspective of a skilled person in this field, intuitively it might appear that only a mask on the 
order of a major fraction of a full-page image would suffice to truly eliminate conspicuous patterning From that per- 
spective the results of these copending patent documents appear to be perhaps some two orders of magnitude 
away, in terms of mask size, from such an expectably successful size standard. 

Earlier masks have been small. In the printing-medium advance direction (vertical for a portrait-format image) 
mask height customarily has been equal to the number of nozzles divided by the number of passes or an even 
smaller quotient. In the scan-axis direction (horizontal), mask width ordinarily has been equal to the height or less 

— typically eight to thirty-two pixels. 

These numbers represent very small fractions of a full-page image width at the modern resolution standard of 
twenty-four pixels per millimeter (six hundred pixels per inch). Even increasing mask size to. say a third or a half of 
full-page width calls for an increase by a factor of some fifty to seventy. 

That is a daunting prospect, since such very large masks require very large memory _ and different masks 
are required for various conditions, particularly including type of printing medium as well as printing speed The 
crossoombinations of these conditions rise quickly to require at least some eight or twelve different masks. The cost 
of storing not one but numerous manufacturer-supplied multimegabyte-size masks, and the competitive handicap 
of requiring such mask storage in a computer attached to a printer, are all but prohibitive 

The picture as seen from the current generation of advances is similarly adverse with regard to generation of 
such large masks in the field. While the Serra results may provide somewhat better image quality, both the Serra 
and Chang algorithms appear to be too expensive computationally to implement in onboard processing systems of 
a printer, or even in a printer driver operable in most personal computers. 

With such a strategy, a mask-building program might be started on a workstation to operate overnight and the 
next day one or two more-or-less valid solutions might be found to test with real conditions. This alone points up a 
major drawback at a conceptual level: it is analogous to assigning a lower primate to press typewriter keys essen- 
tially at random - with a person necessarily inspecting the results from time to time to see whether what was typed 
5*> maKes sense. 

If not. the person discards ail of that and the animal starts again -a painfully inefficient procedure. Moreover 
notwithstanding commitment to such a computationally intensive method, as already indicated the masks built in 
this way were rather small, on the order of sixteen by thirty pixels 
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Another of the current generation of advances in the printmasking art, the Doron document mentioned earlier, 
proposes building a good mask automatically at each effort, and suggests that this may. be accomplished within a 
printer in the field and in real time fi. e.. when or shortly before the mask is needed). Doron indicates that a differ- 
ently configured mask is selected for each printing operation — that is, for each printer pass in a repeating series 
s of, say, four or five passes — and his approach evidently thus entails use of not one but several discrete masks for 

each image. 

The printer selects a different one of these masks for each pass, which is to say that different masks are 
applied to printing of different image portions. In the earlier procedure of building a mask, Doron's procedure oper- 
ates in a three-dimensional space that is a vertical stack of pixel grids, each successive grid or plane representing 
io a higher layer of inkdrops applied in succeeding passes, or by later-arriving nozzles in a single pass. 

Doron appears to introduce randomness at two stages of his procedures. First, in the mask-building stage he 
randomly selects a series of vertical columns in the stack — e. a., columns that underlie particular pixel positions 
in the topmost grid — for processing, one column at a time. 

In processing each column he f ills-in printing parameters for the several grids in the stack, observing selection 
15 - ; rules that refer to columns which have been previously filled in. The selection rules appear to result in an essentially 
deterministic series of selected "parameter" numbers don the column, given the columns filled in previously. The 
random order of column selections in this way controls the final overall three-dimensional array of parameters. 

Second, at run time Doron's control program randomly selects one of a number of the randomly generated 
masks for use in each "printing operation" as mentioned above. The degree of randomness in his pseudorandom 
20 system appears to be fixed by these two processes. 

Although it uses plural masks in conjunction for printing of each image, his system appears to require relatively 
modest quantities of data storage. It requires more than just the storage for one mask, but less than would be 
required for permanent storage of all necessary masks, and a small amount in total because each of his masks is 
rather small. 

25 The efficacy of the system is unclear, in that it attempts to rely upon continuously shifting among several avail- 

able masks to break up patterning but the individual masks are small. Doron's mask height (i. e. a y_ dimension in 
the pixel grid) is his pen height, preferably one hundred twenty-eight pixels; however, his most-highly preferred 
mask width is said to be only thirty-two pixels. 

Thus if the number of masks is also rather small, some potential for repetitive patterns breaking through may 

30 remain. On the other hand if the number of masks is adequately large and the selection truly randomized, then the 
system may exhibit adverse effects of highly random masking. Since such effects are part of the recognitions driv- 
. ing the present invention, they will be explained further in the following sections. 
(0 Conclusion — As shown above and elaborated in the following sections, various obstacles of computing time, 
data storage, a fixed degree of randomness and repetitive small or narrow (although randomized) mask patterns 

35 have continued to impede achievement of uniformly excellent inlqet printing — at high throughput — on all indus- 
trially important printing media. Thus important aspects of the technology used in the field of the invention remain 
amenable to useful refinement. 

SUMMARY OF THE DISCLOSURE 

40 

[0009] The present invention introduces such refinement Before proceeding to a relatively rigorous description or def- 
inition, this section offers some informal comments that are for orientation only and should not be taken as defining the 
invention. 

[001 0] The terms "printmask" and "shingling mask" may be used interchangeably. Dither masks are used for a differ- 
45 ent purpose, as outlined earlier, and accordingly have distinctly different microstructure. Each of these three terms, 
however, refers to a two-dimensional array of cells in which each cell contains a given amount of ordered numbers. 
(Slightly nonidiomatic phrases such as "amount of . . . numbers" are used in this document in preference to phrases 
such as "number of numbers" that are idiomatically more common but confusing.) 

[0011] In dither masks, each number in the cell represents, most typically, a discriminator number against which 
so essentially a continuous-tone (or high-multilevel) signal is tested to determine whether inking in the corresponding pixel 
will occur or not. It is a decisional tool relating to spatial distrtoution of ink spots. 

[0012] In printmasks, each number in the cell represents a pass in which a dot will be printed. Stepping or "tiling".this 
array in two orthogonal directions over the print medium describes the pass in which the printhead will fire each drop; 
thus a printmask is a decisional tool relating to temporal distribution of the spots ordained by the halftone or dither proc- 

55 ess. 

[0013] The amount of numbers in a printmask cell equals the maximum number of drops that the printer can fire in 
any given pixel (dots per pixel, or "dpp"). The order of the numbers in the cell corresponds to the order of passes in 
which to fire: that is, the first number will be used for the first drop, the second number for the second drop in the same 
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pixel location, and so on. 

[001 4] For a printer that can fire two drops per pixel, for example, the first number in a cell represents the pass number 
in which the first drop is to be fired; in case of firing a second drop, the second number will be used. A halftoning algo- 
rithm, which may operate in the printer or in an associated printer driver in a connected computer, controls the number 
5 of drops to lire in a given location. 

[001 5] The ordered set of numbers in each cell can be interpreted as representing a third dimension. A three-dot-per- 
pixel mask, for example, can be represented by three two-dimensional arrays, each one containing just one number per 
ceil, and representing one level. 

[001 6] If only one drop has to be fired, the number in the lowest level array will be used; if two drops have to be fired, 
io the numbers in the lowest level and the second level arrays will be used. In this document the arrays representing each 
level will be referred to as layers or planes — not to be confused with the color "planes" often mentioned in connection 
with multicolor printing. 

[0017] This approach does not yield a completely general notation for masking. It implies that, if pass number n is 
being used when one drop has to be fired, passes a and m will be used for firing two drops, and passes number a, m 
15 and g for three drops. It could be desirable, though, to use pass n for just one drop but passes rn and g for two drops. 
The first approach may be called sequential, and will be the only one addressed here. 

[001 8] Designing a printmode determines the strategy that the printer will follow to put drops onto the paper. This strat- 
egy has to respect certain restrictions, and tries to accomplish certain goals of print quality and throughput. 
[001 9] The restrictions come from the physics of the pen and ink-media interaction: firing two consecutive drops, for 

20 instance, could cause the firing frequency of the pen to be too high, or placing two drops next to each other in the same 
pass would cause coalescence. Goals often come from marketplace considerations, and for dither masks they may 
take the form of "effective resolution of image detail finer than" a specified value; for printmasks they may instead take 
the form of "banding free" at some specified distance, or "better color gamut than" a specified product, or "image quality 
higher than" some known reference standard. 

25 [0020] This document relates to an invention which in part represents an advance because it focuses on the restric- 
tions, and particularly upon unambiguous ways to define them in symbols. Such notations will be described, and an 
analysis of the conditions under which it is always possible to create a mask that satisfies the restrictions will be offered. 
[0021] The invention provides or includes a method for synthesizing masks, given restrictions expressed in such a 
form and under just such conditions. In contrast to related approaches discussed in an earlier section, the present 

30 invention defines a set of constraints — the grammatics, so to speak, which the unfortunate animal previously men- 
tioned was supposed to respect, but was never taught. 

[0022] The invention thereby, within the immediate process of building a mask, makes certain that every single ele- 
ment of the mask is going to respect them. This approach assures that every run of the algorithm will provide a valid 
solution. In comparison with the overnight techniques required to produce possibly usable 16x30 masks, the present 
35 invention operating on the same workstation finds a guaranteed-valid 512x512 mask in two or three seconds. 

[0023] Small mas ks, large masks and the odds of finding a usable mask — Design of print modes has traditionally 
been limited to small printmasks, something like sixteen pixels wide by two hundred forth pixels tall. Such a limitation, 
together with a helpful restriction that divides the nozzles into zones corresponding to the number of passes, makes the 
problem a tractable one. 

40 [0024] It is still difficult, but tractable. A writing-systems engineer can draw zeros and ones in the places where it is 
desirable for the pen to fire — and then can visually inspect the result, make sure the restrictions are respected, and 
even draw a nice pattern. 

[0025] This method decides the strategy for putting the drops on the paper, looking at the pen . A printmask is 
designed to be the size of the nozzle plate, and in effect is something the pen carries with it. This has an important draw- 
45 back: every defect, every pattern, will always be repeated in every swath the same way, thus having the tendency to 
produce bands. 

[0026] This is where large printmasks can come into play. The basic idea is to change the focus from the pen to the 
pjot. It is not necessary to be restricted to something the size of the pen that will be repeating. Instead it is possible to 
look at the plot and decide to ink one particular pixel in the first pass, another particular pixel in the fourth, and so on. 
so In principle this can be done with any number of pixels, even with the entire image frame. 

[0027] This approach, however, can no longer be followed with the traditional methods of the writing systems engi- 
neer. No amount of skill or patience would enable the engineer to manually find, for example, a 1024x1024 array of 
numbers that fulfills the required restrictions. 

[0028] Given a certain number of passes, there is a maximum number of restrictions that will leave degrees of free- 
55 dom to find the mask. More specifically, if the number of restrictions (expressed in a particular notation discussed later) 
is lower than the number of passes, it will always be possible to solve the problem with a deterministic algorithm. 
[0029] If the number of restrictions is equal to or higher than the number of passes, finding a mask becomes a prob- 
abilistic exercise that depends on the size of the mask (it is possible to compute the probability). Such a mask is over- 
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constrained and will not be possible to find with a deterministic straightforward algorithm. In general, it will require a 
■number of iterations roughly related to the probability of finding a solution. 

[0030] If the desired mask is small, even if the restrictions overconstrain the problem, it is relatively easy to find a solu- 
tion. The odds, however, decrease drastically as the size of the mask increases. 

5 [0031 ] The Tools, and How to Work with Large Masks — The innovations described in this document are associated 
with development of a computer program that, given a set of restrictions and a definition for the mask (size and number 
of passes), will try to find a mask that fulfills the restrictions. The phrase "try to find" here means that if the problem is 
underconstrained, the program will always find the mask on the first attempt; and if the problem is overconstrained it will 
sometimes find a solution and sometimes not. 

10 [0032] This program can be caused to run in printer firmware, or in the processes of an application-specific integrated 
circuit (ASIC), or as part of a printer driver that in turn is running in a computer attached to a printer. The program can 
be used in a number of ways: 

[0033] It can help in the design of small masks. It can be used to find underconstrained masks straightforwardly. 
[0034] More interestingly, together with a shell script it is also able to find overconstrained masks; or it can be piped 
15 to another program and there used to find a mask that has certain special properties. In these last two cases, it 
becomes a new but much more sophisticated form of the previously discussed analogy to animals typing — but now 
with no need for human intervention to check quality. 

[0035] It also can do the design of a laroe mask, as for instance a printmask that can be tiled with a set of restrictions. 
Again, if such a mask is underconstrained the program will always produce a solution. 
20 [0036] If the large-mask problem is overconstrained, the number of trials needed will depend on the probability of find- 
ing a solution (in general, the number of trials may be unacceptably large). In this case the design can take either of two 
different approaches: 

■ The designer of a mask decides what restrictions are necessary, how many passes and so on, and produces a 
25 mask of the desired size. This mask goes to the printer or driver, where it is stored and used. 

In this case, the mask can be overconstrained (assuming the designer thinks this is necessary, and has 
enough computer power and time to find it). An important drawback is that the mask will have to be tiled, and this 
implies more restrictions. 

■ The designer of the mask decides on the restrictions, number of passes and so on, and the printer uses them to 
30 produce the mask on the fly — in other words, in real time, while actually printing an image. This has two great 

advantages, coming from the fact that the mask doesn't have to be tiled: there are fewer restrictions, and there are 
no repeating patterns. 

[0037] It also has disadvantages: the mask has to be produced straightforwardly, so it cannot be overconstrained. This 
35 approach also requires some computing power from the printer, but it appears feasible with some modern printers 
which answer to that requirement. 

[0038] Constraints — a constraint for present purposes is defined as any design criterion that a mask is expected to 
satisfy. Two main types of constraint are currently in use: spatial constraints and (primarily for printmasks) pen-usage 
constraints. Constraints can be applied within a single plane of a mask, between planes, or between different masks 
40 (for example, to make certain that yellow will not print in the same pass as cyan). 

(1 ) Neighborhood constraints — These are spatial constraints that define restrictions on the placement of dots with 
respect to a pivotal point (a central point in a constraint diagram as will be seen below), as a function of their relative 
position or so-called "distance", or both. In this section, which will be found most natural if interpreted in terms of 
45 printmasks, "distance" always means a difference between two pass numbers — so that in effect this "distance" is 
measured in units of time . 

For example, if a position in the mask that has a value of four is at the pivotal point, and the neighbor in the 
relative position (-1 ,0). the point immediately to the left, has a value of one, then the distance is 4 - 1 = 3. Note also 
that since the number of passes is a repeating sequence from one to n, so that the pattern in effect wraps, the dis- 
50 tance between n and one is one, not n - 1 . 

All the points in the mask should comply with all neighborhood constraints. Neighborhood constraints are 
always defined as a function of relative positions with respect to a pivotal point: all the points in the mask should be 
able to function as pivotal points, and satisfy the defined constraints with respect to the defined neighbors. The only 
exceptions are the boundary cells of the mask; it is often favorable to define different neighborhood constraints for 
55 the center of the mask from those of the borders — the latter being sometimes called "seam constraints". 

A general way to describe neighborhood/spatial constraints is defining, for any given neighbor, a weight for any 
given distance (distance, again, is here the difference between two pass numbers). The weight goes from zero 
(meaning forbidden) to one (meaning accepted). 
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For a particular pivotal point that can be any point in the matrix, constraints specify a set of limitations in tens 
of pass numbers for the neighbors. For example, this scheme — 



5 


default 1 










( 0,1) 


# 


the upper neighbor 






[0:0.0] 


# 


distance 0 (i . e . same plane) , weight 0 . 0 


10 


[1:0.0] 


# 


distance 1, weight 


00 (i. a, forbidden) 




(-1,0) 


# 


the left neighbor 






[2:0.1] 


# 


distance 2, weight 


0.1 ("almost forbidden") 


15 


[4:0.1] 


# 


distance 4, weight 


also 0.1 



means that, for any given position in the mask, the upper neighbor has to be at least two passes away (cannot be 
equal, and cannot be either the preceding or the following value), and the left neighbor should be within a distance 
so of zero ; one, three or five (assuming for instance a printmask in a six-pass print mode). 

This approach easily allows for constraining a mask such that no solution exists. Therefore care must be taken 
to ensure that a solution space does exist. 

Another, less general but more intuitive way of specifying neighborhood constraints is the constraint matrix It 
s.mply sets a value for each neighbor. That value is the distance, in number of passes, outside which the neighbor 
25 is expected to be from the pivotal point. In this example — 

{00100} 
{01110} 
{12x11} 
{00100} 



30 



the "jc" represents the pivotal point. The two to the left of the x means that the left horizontal neighbor is supposed to be 
outside an open range of two centered on *. If for example x. = 4, the left neighbor can be anything except three four or 
five. Every point in the mask, when considered the pivot point, should comply with these restrictions 

Neighborhood constraints can be applied within a single plane of a mask, or can be used to relate different 
planes or different masks between them. As an example, suppose that an eight-pass printmask is to be built for a 
pnnter that can print two drops per pixel, but can only print one drop in a given location per pass. The mask must 
have two planes, and the two numbers corresponding to the same pixel on the two planes must always be different 
Additionally, no point should fire in the same pass as the preceding or following pixel. These constraints can be writ- 
ten as follows, and will be explained below. 

For the first layer : {1x1} — applied to itself 

For the second layer : {1x1} — applied to itself 
and 

pixel pa s s : we igh t 
50 ( 0,0) [0 : 0.0] ] 

(-1,0) [0 : 0.0] \ — applied to the first layer 

( 1,0) [0 : 0.0] J * 



35 



40 



45 



55 

The first-layer constraint, and the first constraint in the second-layer set, are the same. "{1 x 1V\ This means that 
no consecutive neighbors are firing in the same pass. 

The following group of constraints for the second layer has three lines. The first line says that, for the position 
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(0.0) — that is, for the same location, but in the other layer — at a distance of zero, or in other words in the same 

pass, the weight is 0.0, forbidden. Thus two drops cannot be fired into the same pixel-grid location in both passes. 

The next two lines in the second-layer constraints enforce a requirement that the point in the second plane must 

also be different from the two horizontal neighbors in the first plane. 
5 The neighborhood constraints have a symmetry redundancy. If the constraint {1 x} is imposed for all the points, 

the converse constraint {x 1 } will also be fulfilled. 

This property will be called polar symmetry. It represents a mathematical generalization that is important to the 

most-efficient practice of the invention, since it facilitates the progress of mask-building along a simple track from 

one corner of the mask grid across the first row, and then rasterwise similarly across the next row and so forth. 
io (2) Pen-usage constraints This type of constraint specifies restrictions in the way the nozzles of the pen are 

used. For building printmasks, the fast mask generation method currently uses two types of nozzle constraint: 

■ Nozzle-usage acceptance defines the level of acceptability of a given nozzle. Acceptability of zero means for- 
bidden, acceptability of one means accepted without restriction. Any number in the closed range [1,0] is 

is allowed. 

■ Nozzle-usage distribution defines an expected or intended distribution of the nozzles. Here a one still means 
unlimited usage and a zero means forbidden, but the values within the range are specific fractions of use, or 

. duty cycle, desired. 

20 As an example of the difference between these two kinds of constraint, rf 0.1 is specified as the usage acceptance 
of a particular nozzle, that nozzle is acceptable to use but only if there is no better option. If 0.1 is specified as the 
usage distribution of a particular nozzle, then when printing with the fully created mask this nozzle is expected to 
be used exactly ten percent of the time it would have been used normally — Le, in a conventional system. 

25 [0039] Basic algorithm — The building of a multilayer, sequential mask thus can be reduced to the problem of building 
each layer of the mask, with some constraints acting between layers. The fundamental algorithm preferably builds a 
plane by traversing the matrix sequentially, top-down and left-to-right (although other orders can be used without loss 
of generality). 

[0040] When any given position of the mask is to be filled, all the existing neighbors (both in the plane being built and 
30 in the reference planes) have to be checked following the neighborhood-constraint definitions. The nozzle-usage 
acceptability and distribution tables, too, have to be checked. This implies, for each pass number, computing the nozzle 
that will fire it, checking this nozzle in a lookup table, and assigning the weight to the pass number in accordance. 
[0041 ] After all the constraints have been applied to all the pass numbers, a set of weights for each possible candidate 
(pass number) is defined. The next step is to consolidate the different weights assigned to each candidate into one 
35 number. 

[0042] The fast mask generator algorithm does this by assigning a zero (forbidden) for the final weight of a zero is 
present in any of the values assigned by the constraints, or otherwise a weighted average of all the values. Each value 
is weighted by the relative importance that the constraint which set it has assigned. 

[0043] After all the candidates have been assigned a weight, taking into account all the constraints, a candidate has 
40 to be chosen to fill the position. The algorithm offers two approaches: the deterministic approach, which consists in 
choosing the best option (the candidate that has the highest weight), and the randomized approach, which treats the 
weight of each candidate as a probability. 

[0044] Using the first option typically yields very ordered masks. The second option gives more random masks, with 
appearance that is more grainy but less mottled ( i. e. repetitive). 
45 [0045] Actual implementation of the algorithm allows the user to choose a degree of randomness: a value between 
zero and one, meaning the fraction of points within the mask that are to be chosen using the randomized strategy. All 
the rest are assigned deterministically, IjSl, by picking the highest weighted candidate. The points that will be set with 
the randomized strategy are also randomly selected. 

[0046] In one desirable variant, the degree of randomness is chosen automatically in response to an analysis of 

so "activity" in the image. This form of the invention will be explained more fully below. 

[0047] The foregoing may convey a general flavor of the subject matter of this document. This discussion now turns 
to a more formal presentation. In its preferred embodiments, the present invention has several aspects or facets that 
can be used independently, although they are preferably employed together to optimize their benefits. 
[0048] In preferred embodiments of a first of its facets or aspects, the invention is a method of preparing and using a 

55 mask for incremental printing, using a preestablished program that incorporates complete conditions for a usable mask. 
The method includes the step of automatically operating the preestablished program that incorporates complete condi- 
tions for a usable mask. 

[0049] This step produces a usable substantially unitary mask in substantially each attempt by the program. The 
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method also includes the step of then automatically using the produced substantially unitary mask — or storing it for 
later use. The produced mask is for use substantially in common over an entire image, and substantially without human 
intervention as to mask content. 

[0050] The term "unitary", and the reference to use "substantially in common over an entire image", for purposes of 
5 this document, merely mean that one single mask pattern is used throughout printing of an image — in other words, 
that no more than one pattern is used. The mask, however, is not necessarily the size of the full image or a full page! 
As will be seen shortly, the mask may be either such a full-size mask or a smaller mask that is stepped or "tiled" across 
the image or down the image, or both. 

[0051] The foregoing may constitute a description or definition of the first facet of the invention in its broadest or most 
io general form. Even in this general form, however, it can be seen that this aspect of the invention significantly mitigates 
the difficulties left unresolved in the art. 

[0052] In particular, as will be seen in following sections of this document, the very capability to produce a mask very 
reliably and systematically is a key to correcting those difficulties. This first aspect of the invention accordingly elimi- 
nates the conventional reliance upon masks that are too small to avoid repeating patterns, and masks that are at the, 
is same time too large to provide economically within a printer, and masks that must be prepared at the factory and there- 
fore cannot accommodate operating conditions. 

[0053] Although this aspect of the invention in its broad form thus represents a significant advance in the art, it is pref- 
erably practiced in conjunction with certain other features or characteristics that further enhance enjoyment of overall 
benefits. 

20 [0054] For example, it is preferred that the operating step include the substeps of: 

considering candidate pass numbers, for a particular position in the mask, and expressing the favorability of each 
candidate pass number, with regard to each of plural neighboring positions, as a "neighborhood constraint" in the 
form of a respective weight; 
25 consolidating the weights to obtain a single measure of favorability for each candidate pass number; 

based on the single measure of favorability. choosing one of the candidate pass numbers for use at the particular 
position in the mask; and 

repeating the considering and expressing step, the consolidating step, and the choosing step for each other posi- 
tion in the mask. 

30 

Other preferences include limiting mask production based on relationships among successive layers of colorant; 

controlling the number of constraints so that adequate degrees of freedom remain to ensure that the program can 
find a solution in substantially each attempt; 
35 automatically selecting a balance between the relative degree of randomness and determinism in a mask to be pro- 
duced; identifying nearby positions only by a substantially generalized explicit notation that is relative, substantially 
without reference to absolute position in the mask; 

and with respect to each nearby position that is thus identified by the generalized notation, expressing in only a sub- 
stantially generalized explicit notation the acceptability of inking said pixel position in particular inkdrop planes of 
40 the mask. 

[0055] Generalized notation is an important preference in the successful practice of this invention. One preferred type 
of such notation is use of a first numerical value representing a particular distance in three dimensions within the suc- 
cessive inkdrop planes; and coupled with the first numerical value, a second numerical value representing acceptability 
45 of inking at said particular distance. The significance of that second value may be aprohibition of inking, a relative per- 
missibility of inking, or a relative probability to be applied in determining inking. 

[0056] Another type of generalized notation includes a local grid including a representation of the pixel position of 
interest and some nearby pixel positions; and in at least some positions within the local grid, relative to the pixel under 
calculation, a numerical representation of the permissible or preferable distance to a position where inking may occur. 
so it has been found that this type of notation is particularly powerful when the expressing step includes applying a condi- 
tion that is substantially polar symmetric. 

[0057] A second aspect of the invention is a method of preparing and using a mask for incremental printing. The 
method includes the step of, for a particular pixel position in a mask to be prepared, determining a multiplicity of numer- 
ical weighting values that respectively represent relative acceptability of inking in a particular inkdrop plane with respect 
55 to each of a multiplicity of operating conditions or other nearby positions. 

[0058] Another step is consolidating the multiplicity of numerical weighting values to determine substantially a single 
numerical weighting value that represents overall relative acceptability of inking at the particular pixel position in the par- 
ticular inkdrop plane. 
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[0059] The foregoing may constitute a description or definition of the second facet of the invention in its broadest or 
most general form. Even in this general form, however, it can be seen that this aspect of the invention too significantly 
mitigates the difficulties left unresolved in the art 

[0060] In particular, the use of weightings in a generalized notation represents an extremely powerful strategy for tak- 
5 ing into account a very large number of operating conditions and constraints of various kinds, particularly with respect 

to inking levels in different inkdrop layers or planes. Thus again this second aspect of the invention serves as a key to 

resolution of difficult obstacles to a mask-generating system that can function quickly and yet with extreme reliability. 

[0081] Preferences in regard to this second aspect of the invention will be elaborated further, later in this document. 

They particularly include evaluating the potential use of certain print nozzles for inking at a particular pixel position in a 
w mask to be prepared; and taking into account the results of the evaluating step in determining relative acceptability of 

inking that particular pixel position, in a particular inkdrop plane, to prepare the mask. 

[0062] In a third basic aspect or facet, the invention is a method for generating and employing masks for use in incre- 
mental printing, using a self-standing input text file of mask constraints, and also using a mask-generating control algo- 
rithm. The program includes the step of automatically reading the self-standing input text file to accept such constraints. 
15 [0063] Another step is automatically accepting any definition of a mask-generating modular control algorithm that 
applies the mask constraints. Still another step is automatically generating a mask, under control of a printmask-gener- 
ating modular control algorithm. 

[0064] Further steps include automatically operating the defined mask-generating modular control algorithm to apply 
the mask constraints and thereby control the mask-generating step; and automatically forwarding the generated mask 

20 for use, or for storage and later use, in a printer or a printer driver for operating the printer to print images. 

[0065] This third aspect of the invention thus focuses upon modularity of the primary algorithm or algorithms, as well 
as other forms of input. This characteristic renders the invention as a tool still more powerful. A preference in regard to 
this facet of the invention is combination of the host program with a mask-generating modular control-algorithm def ini- 
tion, functionally interfaced to the accepting step for acceptance thereby. 

25 [0066] In a fourth aspect, the invention is a method for generating and employing masks for use in incremental print- 
ing, using a self-standing input text file of mask constraints, and also using a mask-optimizing control algorithm. The 
method includes the step of reading the self-standing input text file to accept such constraints. 
[0067] It also includes applying the accepted constraints to generate a mask; and accepting any definition of a mask- 
optimizing modular control algorithm that receives said generated mask as an input and reprocesses said received 

30 mask to substantially optimize it for image quality. Other steps are operating the accepted mask-optimizing modular 
control algorithm to reprocess said received mask to substantially optimize it for image quality; and forwarding the opti- 
mized mask for use, or for storage and later use, in a printer or a printer driver for operating the printer to print images. 
[0068] This aspect is particularly useful in that it provides a program that can correct its own imperfections in first- 
round mask generation efforts, if more-highly optimized results are desired. 

35 [0069] All of the foregoing operational principles and advantages of the present invention will be more fully appreci- 
ated upon consideration of the following detailed description, with reference to the appended drawings, of which: 

BRIEF DESCRIPTION OF THE DRAWINGS 

40 [0070] 

Fig. 1 is an exemplary small constraint matrix for discussion in introducing some restriction notations used in prac- 
tice of preferred embodiments of the invention; 
Fig. 2 is a diagram representing a mask matrix ; 
45 Fig. 3 is a diagram representing a generalized constraint matrix; 
Fig. 4 is another exemplary small constraint matrix; 
Fig. 5 is a small exemplary portion of a mask; 

Fig. 6 is an exemplary application of the Fig. 4 constraint matrix to the Rg. 5 mask; 

Fig. 7 is a symbolic statement of the operation of a constraint matrix; 
so Fig. 8 is a generalized but small constraint matrix; 

Fig. 9 is a small portion of a generalized mask, to which the Fig. 8 constraint matrix has been applied; 

Fig. 10 is a symbolic statement of forward-compatibility constraints for the case of Figs. 8 and 9; 

Fig. 1 1 is a symbolic statement of the amount of numbers forbidden by the Fig. 10 constraints; 

Fig. 12 is a statement like Fig. 10. but instead for backward-compatibility constraints; 
55 Fig. 13 is a symbolic statement of the amount of numbers forbidden by the Fig. 12 constraints; 

Fig. 14 is a symbolic statement of a symmetry condition that equalizes the Fig. 10 and Fig. 12 constraints; 

Fig. 15 is a polar-symmetric matrix derived from the Rg. 8 constraint matrix when subjected to the conditions of Fig. 

14; 
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Fig. 16 is a mask matrix like Fig. 5, but instead for the last column of a mask that has to be tiled; 
Fig. 17 is a pair of statements like Figs. 10 and 12, but instead for the Fig. 16final column; 
Fig. 18 is a matrix like Fig. 16, but instead for the last row of the mask; 
Fig. 1 9 is a pair of statements like Fig. 1 7. but instead for the Fig. 1 8 last row; 
5 Fig. 20 is a diagrammatic model of a preferred usage of the constraint space for polar-symmetric matrices only; 

Fig. 21 is a symbolic definition of multiple sets of forbidden mask entries, related to discussion of probabilities and 
feasibility conditions; 

Fig. 22 is an associated symbolic statement of a basic feasibility condition; 

Fig. 23 is a symbolic statement of the probability of finding a certain number in a certain set of forbidden numbers; 
io Fig. 24 is a like statement of finding such a number in one such set but not another such set; 

Fig. 25 is a symbolic statement of an average amount of numbers belonging to two such sets; 
Fig. 26 is a symbolic statement of a joint probability of being able to fill a particular mask position; 
Fig. 27 is a diagram of a general polar-symmetric matrix following the Fig. 20 model; 

Fig. 28 is an enlarged rendering of a mask made with a high degree of determinism, wherein the various pass num- 
15 bers are mapped to shades of gray for an intuitive presentation of the character of such a mask; 
Fig. 29 is a like rendering of a mask made with a high degree of randomness; 

Fig. 30 is a like rendering of a mask made with intermediate degrees of determinism and randomness; 
Fig. 31 is a simulation of a printed midtone gray made with the mask of Fig. 28; 
Fig. 32 is a like simulation made with the mask of Fig. 29; 
20 Fig. 33 is a like simulation made with the mask of Fig. 30; . 

Fig. 34 is a class diagram, showing key classes of a program used for implementation of preferred embodiments of 
the invention; 

Fig. 35 is a representation of an exemplary cell in a composite mask, particularly for a three-drop-per-pixel mask; 
Fig. 36 is a pair of exemplary restrictions within a cell such as that of Fig. 35; 
25 Fig. 37 is another exemplary cell but for a four-drop-per-pixel maximum deposition per pass, and a total of eight 
passes per pixel; 

Fig. 38 is a symbolic statement of a condition on the Fig. 37 cell; 

Fig. 39 is an exemplary constraint matrix for discussion of composite-mask constraints; 

Fig. 40 is a general format for a cell of d drops per pixel; 
30 Fig. 41 is a likewise general format for a composite mask; 

Fig. 42 is a general form of a constraint matrix for such a mask; 

Fig. 43 is a general form of a polar-symmetric constraint matrix for such a mask; 

Fig. 44 is a block-diagrammatic representation of a hardware system according to the invention; 

Fig. 45 is a diagram showing very schematically the size of a mask created according to preferred embodiments of 
35 the invention, relative to spatial frequencies to which the human eye is typically most sensitive;; 

Fig. 46 is a highly schematic diagram illustrating the imposition of pen nozzle modulations by the mask-creation 

block in Fig. 44; 

Fig. 47 is a very schematic diagram showing the use of intentionally nonaligned nozzle groups in substantially 
aligned pens; and 

40 Fig. 48 is a flow chart showing operation of procedines preferably performed by the hardware system. 
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 
1. BASIC APPROACH 

45 

[0071] This section introduces with an example the novel method for building large masks. A more-general presenta- 
tion appears in the next section. 

[0072] The Mask — The mask is just an array of numbers, each one over a pixel, that in a printmask represent the 
pass in which that pixel will be printed and in a dither mask represent a discriminator against which input levels are to 
so be tested. For example, the following printmask. with eight passes: 
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(continued) 
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4 



means that the first dot of the first row will be fired in pass five, while the second dot of the first row will not be fired until 
pass six, and so on. Thus the mask is always something that is directly related to the dots on the drawing: each dot 
(each position in the mask) will have a pass number in which to be fired. 

t°° 73 l The Restrictions — These are expressed in the form of a matrix, called the constraint matrix. This matrix will 
have a center point (Le,, the number of rows and the number of columns are odd numbers), which will be called the 
pivptal point. 

[0074] The meaning of the constraint matrix is the following. When the center point of the matrix is placed over any 
position on the mask, this position cannot be fired in the same pass as those neighbors in the mask that are beneath a 
one ("1 ") of the constraint matrix. 

[0075] Consider as an example the constraint matrix that is shown as Fig. 1 . Alternative graphical ways of saying the 
same are — 



20 
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25 where the grey squares or those containing a "Y" represent the neighbors that will be taken into consideration, the white 
square or the one containing an "X" is the pivotal point, and the black squares or those marked "N" are the neighbors 
that will not be taken into consideration. 

[0076] Next consider the following mask (the same as before, with eight passes, but now without the center value) — 

30 
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40 

and we want to find a legal option for the center pixel, the one containing a question mark. We would put the constraint 
matrix with the pivotal point over the position in question, thus getting something like the following. 
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The grayed numbers (corresponding to the "Y" entries in the previously shown lettered form of the constraint matrix) are 
55 the forbidden values. This means that three, two. eight, six, four and one are not legal pass numbers for the center point. 
The only options are five and seven. It is preferable to choose seven, as five is in the same row just two positions before* 
[0077] Building the mask — Next will be shown a method for building the halftoning mask or the printmask This will 
be done by rows: beginning with the first pixel in the first row, doing all the first row, and so on. If the process has been 
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followed down to the second pixel of the third row. the mask is like — 



10 



5 


6 


4 


7 


1 


7 


1 


3 


2 


4 


5 


8 





























15 



and the next value is now to be chosen (in a printmask it is the pass in which the center point will be printed). The first 
step is to look at the restrictions imposed for the new point. This means superimposing the constraint matrix, in this way : 
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The forbidden values for the new point are seen to be three, two and eight. 

[00781 There are. however, more restrictions. What has just been done is to make sure that the new point will be legal 
but there are other points already assigned that must continue being legal! This means that it is necessary now to put 
the constraint matrix over the neighbor points already assigned, and see what restrictions are imposed by doing so. 
[0079J Positioning the mask over the one shows that it imposes no restrictions on the central pixel: 
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[0080] Placing the mask over the three yields: 
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55 



which requires that the candidate for the new position cannot be a three. 

[0081] If in like fashion the constraint matrix is positioned over all the neighbors of the central candidate, the values 
forbidden by the fact that the values already there have to continue to be legal would be seen to be three, two and eight. 
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These are precisely the same conditions previously found for the new value to be legal. 

[0082] There is, however, a reason other than coincidence for this extremely powerful simplification: the constraint 
matrix has a certain "symmetry". If the lower right corner were instead a one (shadow) instead of a zero (black), then 
placing the constraint matrix over the one (see two masks above), would reveal that the one had become a forbidden 
s option. That would mean that the conditions needed to continue to assure the legality of numbers already there would 
not be the same as the conditions needed to assure the legality of the new option. 

[0083] This observation has a very important implication, which is a cornerstone of the preferred method: if constraint 
matrices follow this kind of special symmetry, which will be thoroughly defined below, it is necessary to look at only one 
set of the conditions to be sure that all the conditions will be satisf ied. In other words, the mask can just be constructed 
10 in a continuing forward progression without ever looking back and changing the numbers that were put in before. 

[0084] The entire printmode mask is created in this manner. Actually, a few more complications arise when the mask 
is tiled —as will be shown in more-complete discussion of the algorithm, below. 

2. DEFINITIONS 

75 

[0085] This section and those following may appear complicated at first sight, but no advanced mathematics is 
required — it is just that the problem involves many variables, and they must be written somehow. 
[0086] A mask will be defined assigning to each pixel a number representing (in a printmask) the pass in which it will 
be printed. It will be represented by a matrix called [M]. For example, in the mask of Fig. 2 the number two in the second 
20 row means: "this pixel will be printed during a printhead's second pass". Its elements will be referred to as m f c , where 
t c have the usual meaning of row, column respectively (both starting at 1). 

[0087] The restrictions will be defined by a (2r+1 )x(2s+1) constraint matrix. This matrix will be called [C], and its com- 
ponents Cjj, where L i will not have the usual meaning: they will refer to the distance in rows and columns to the center 
point as exemplified in Fig. 3. In that matrix, notice that the center point, which will be called from now on the pivotal 
25 point, is not defined (it will be defined for constraint matrices relating different colors). 

[0088] Components of both the mask and the constraint matrix will be a set P of the natural numbers having these 
useful properties: 

a) They have an upper bound, which will be the number of passes, and a lower bound which will be 1. For example, 
30 H the number of passes is 4, possible values are 1 , 2, 3, 4. 

b) They have an internal sum defined in such a way that they "wrap around" at the maximum value. This means 
that, with the previous set. 3+1 =4; but 3+2=5, so it wraps around to be 1 . 

c) They have a way to define intervals that is consistent with the above definition: the interval [a,b] is the set of num- 
bers that results if, beginning with & each number is the preceding plus one, until is reached. In the example 

35 above, the interval [2,4] is the set {2,3,4}, and the interval [4,2] are the numbers {4, 1 ,2}. 

The closed interval [a,b] includes the boundary values; the open interval ]a,b[ does not. 

[0089] The meaning of the constraint matrix is: given any particular position in the mask, if the constraint matrix is 
superimposed over the mask such that the pivotal point is over that particular position, the value in this point of the mask 

40 cannot be in the open range defined by the numbers of the constraint matrix on the numbers of the mask that are below 
them. This definition appears confusing, but the following example will show that the actual application is quite simple. 
[0090] The constraint matrix is appears in Fig. 4, and the number of passes is eight. The objective is to assign a value 
of a point on the mask that appears at in Fig. 5. The constraint matrix should be positioned with the pivotal point over 
that position "?" to be assigned, and the forbidden ranges calculated as suggested in Fig. 6. This means that the forbid- 

45 den numbers for the new position are, beginning with the first row: 

{3}, {4}, {4,5,6,7,8} 
{8,1,2}, , {5} 

50 

Or {3}, {} 



It is clear that all the possible numbers are in the forbidden set, so it is not possible to find any number for the new posi- 
55 tion that satisfies all the conditions. The dean way of defining how the constraint matrix works is as shown in Fig. 7. 
[0091] An interesting subset of the constraint matrices is those matrices which contain only zeroes and ones. The 
candidate has to be different than the preexisting numbers where the constraint is 1 , and there are no restrictions on 
the candidate where the constraint is 0. 
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3. BUILDING THE INTERNAL PART OF THE MASK 

[0092] Given a matrix of constraints, there are a number of ways to construct a mask that fulfills them For example 
positions could be selected randomly, the constraint matrix placed there, and an effort made to find a legal number. 
> This would be easy at the beginning, but would become harder as the mask filled in. 

[0093] The best way to build the mask is probably by filling it by rows or by columns. This makes rt possible to def .ne 
a certain kind of constraint matrix that will make the procedure easier. 
[oSr Sa7wewanttoconstnxtamaskbyrows.Wec^ 

been able to assign values to the mask up to the tS-1 position, and let's see what restr.ct.ons ex.st for the is position^ 
w Rather than a demonstration of this for a general constraint matrix, the derivations will be shown *"°^™^>*" 
matrix to more simply illustrate the principles and procedure - but the more-general express.on ,s d.scussed .n sub- 

[0095i n ^"constraint matrix will be as shown in Fig. 8. and the state of the mask when the next step is to find m^te 
shown in Fig. 9. Notice that, because the construction process is proceeding row by row, after the quest.on mark that 
is is the point of present interest there is currently nothing. ^-.^^ 
[00961 Given a three-by-three constraint matrix with the usual notation, the restr.ct.ons can be segregated nto two 
main groups: restrictions needed to ensure that the numbers already there will continue to be "legal . and restr.ct.ons 
coming from the fact that the new number itself will have to be legal. ,«, a ^*rmr* 
[0097] .^.rt compatibility -For the numbers already there to continue be.ng legal, we have to apply the constant 
matrix to them and see what restrictions are imposed on the candidate. The result appears .n F.g^ 10. 
[0098] in general, each one of the restrictions defines a set of 2 • c.j-1 numbers. (For example, rfwe apply c^StoS. 
we find the interval ]2.8[. which does not include its borders, so the set of numbers is {3.4.5.6.7}). The amount of forb.d- 
den numbers to assure forward compatibility appears as Fig. 11. 

[0099] compatibility - But there are more restrictions: the ones that the new candidate has tosat-sfytobe 
legal itself. We can find them by applying the constraint matrix to the position of ^^'^ 
inFig. 12. Those are the conditions that assure backward compatibility. In general, they w.ll be drfferent from the pre- 
ceding ones, defining Ob forbidden numbers seen in Fig. 13. . ^ „_ 

[0100] Now. from examination of all the conditions, it is clear that some restnctons can be i .mposed uponr thecon- 
straint matrix that will make the backward compatibility conditions equal to the forward compat.bil.ty condrt.ons. Specrf- 
30 ically. if we require — 



20 



25 



c -1 -1 =c 1 .1 ; c -1 .o =c 1 .o: c -1 .-1 =c 1 .1 ; c -i .1 =c i.-i • c 0.-1 ~ c 0.1 

then the backward compatibility conditions are the same as the forward compatibility conditions. This means that with 
35 fco^mtiix Sas appears in Fig. 15. just imposing backward compatibility will ensure forward company. 
This kind of matrix will be called "polar symmetric". 

4. BUILDING THE LAST COLUMN 



roiOH if the mask has to be tiled, the points on the last row and the last column are more constrained - because 
when t is time to put them in. it develops that their neighbors are the list column and the first row. which have already 
been aigned. Accordingly, trying to assign a point in the last column of a mask that has to be tiled .s equ.valent to 

Ume set of conditions as already seen above (but replacing m,.,,^ by m,-i,i). plus two new ones com'ngfromte 
wraparound: forward and backward compatibility as presented in Fig. 17. Assum.ng that the matr.x .s polar symmetr.c. 
here 2 • so ,r 1 new constraints are added. 

5. BUILDING THE LAST ROW 

[0103] Trying to assign a point in the last raw is equivalent to having a mask as shown in Fig. 1 8. The added conditions 
are for forward and backward compatibility appear in Fig. 19. ^„ rfrainte 
[0104] Assuming the matrix is polar symmet^^ 

The most restrictive situation is that of trying to find the very last point. Then the process is at both the last row and the 
55 last column, and all the possible restrictions apply. 
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6. DEFINING THE CONSTRAINT MATRIX TO BEST ADVANTAGE 

[0105] If it is decided to work with polar-symmetric matrices only, then only half of the matrix is actually needed since 
the other half carries redundant information. If the construction is performed by rows, it is possible to actually have three 
5 matrices in one: 

[0106] The first half defines the construction inside the mask, the second half of the middle row (excepting the pivotal 
position) constrains the construction in the last column, and the second half of rows (excluding the center row) con- 
strains the construction of the last row. This is shown in Fig. 20. Defining the constraint matrix in this way allows loos- 
ening the restrictions for the last row or column without changing the construction of the inside of the mask. 

70 

7. FILLING IN THE VALUES 

[0107] The discussion to this point has centered on the constraints — but when ready to fill in a certain position, and 
after having discarded the forbidden values, there are many ways to actually choose the value for that position, from the 
75 range of possibilities. Options that are available include: 

a) just randomly picking one; 

b) assigning to the possible candidates a distribution of probability, that makes it more likely to pick up the ones that 
are "farther away" from the forbidden values; and 

20 c) picking the candidate that is "farthest away" from the forbidden values. 

This list is not intended to be exhaustive. The distribution of probability for option "b)" can be linear, or exponentially 
decaying, or arbitrary, or may follow any number of other functions. 

25 8. PROBABILITIES; CONDITIONS OF FEASIBILITY 

[0108] In trying to fill a certain position in the mask, some sets of numbers will always be forbidden, rf the position is 
inside the mask there will be a certain number of such sets; if it is in the last column the number of sets will be higher; 
if it is in the last row the number of sets will be even higher. 
30 [0109] In general, there will be g different sets, each one with a different number of members n, as seen in Fig. 21 . 
The notation shown there highlights the fact that all the numbers in a given set are consecutive. 
[01 1 0] Condition of feasibility — The condition that assures that it will always be possible to find a number different to 
ail those present in the sets is simple: the number of passes nP has to be higher than the total number of constraints 
as Fig. 22 shows. 

35 [01 1 1 ] Notice that the feasibility can be known just by looking at the constraint matrix and the number of passes. The 
number oj of individual constraints will always be related to a value in [C], n j=2 * Cj k -1 . 

[01 1 2] Degrees o f freedom — The number of degrees of freedom (or The number remaining) can be defined as the 
difference between The number of passes and the total number of constraints, when this value is equal to or higher than 
zero. When the total number of constraints is higher than the number of passes, the number of degrees of freedom 
40 remaining is zero. 

[0113] Overconstrained matrices — If the number of constraints is higher than the number of passes, it is desirable 
to know the probability of being able to find a number that is not already defined as a constraint. The following rough 
analysis by the inventors is subject to refinement through stronger understanding of probabilities; however, as will be 
understood, high accuracy in this regard is not necessary to the general principles of the invention, which have been 
45 found valid in practice. 

[0114] The probability JPj of finding a certain number in the set i is shown in Fig. 23. The probability of finding a 
certain number in the set i and not in the set j. is shown in Fig. 24, where Oi j is the number of values that belong both to 
i and to I 

[0115] In general the exact value of rij j cannot be known, but the mathematical expectation (i. e. the average) in the 
so long run can be found as in Fig. 25. (The derivation of this expression is rather lengthy and not necessary for present 
purposes.) 

[0116] Thus it is possible to calculate the probability of finding a number in any of the sets by adding the probability 
of it being in the first set to the probability of being in the second set and not in the first one, plus the probability of being 
in the third set and not in the preceding, and so on. The probability of being able to fill the position will be one minus the 
55 probability just described. 

[01 1 7] The whole expression accordingly appears as in Fig. 26. Again, remarkably all that is needed to know the prob- 
ability is the number of passes and the values in the constraint matrix. 

[0118] All that has been calculated to this point is the probability of being able to find a certain value in the mask. It 



17 



BNSDOCIO: <EP 0990528 A2_l_> 



EP 0 990 528 A2 

remains to fill the mask. In general, sets of restrictions will be different for the first column and row, for the inside of the 
mask, and for the last column and row. 

[011 9] This means that the probability n mask of being able to find the mask will be something like this product: 

Tf - -rr V, r • 71 Y*c • * Yin • 71 Ylr • 71 Vic 

in which — 



10 



jt fr = probability of f illing a position in the first row 
Vf,. = number of values in the first row 
it fc = probability of filling a position in the first column 
V, c = number of values in the first column 
js n in = probability of filling a position inside the mask 
Yin = number of values inside the mask 
Vi r = probability of filling a position in the last row 
V| r = number of values in the last row 
jt| C = probability of filling a position in the last column 
so V, c = number of values in the last column. 

(This expression is an approximation. For greater accuracy, separate treatment should be given the intersection points 
— the point that is in the first column and the last row, and so on.) 

[0120i The overall probability IW decreases very quickly with the total number of elements V if the probabilrt.es n 
25 are below unity. 

9. CONSTRAINT MATRICES OF ANY DIMENSION 

[0121] A general polar symmetric matrix appears in Fig. 27. The part 1 defines the constraints for the inside of the 
30 mask, part 2 defines those added in the last s columns, and part 3 those added in the last r rows. 

[0122] The number of constraints, and therefore the degrees of freedom, assoaated with any one of ttie zones, is 
easily calculated just by adding up the ranges associated with all the values of the matrix in the zone. Again, the range 
is 2 • Cjj-1 . 

35 10. GENERATING MASKS ON DEMAND 

[0123] Using the fast mask-generating algorithm, masks can be generated by the printer or an associated driver 
whenever they are needed. This arrangement has several valuable advantages discussed betow. including an opportu- 
nity to optimize the design for the specific state of the system and characteristics of the image, as well as enabling a 
40 huge data compression ratio for some masks (particularly large masks). 

[0124] pate compression _ The algorithm for building masks can be understood as a data-compression algorrthm. 
Masks of highest quality are known to require a significant storage capability, and many of them can be required in a 

?0125] Pr °Tnrough use of the present invention it is possible to store only the core algorithm and the constraints, inde- 
45 pendently of the size of the finished mask. Typically storage for the algorithm and constraints is a tiny fraction of a large 
masksize -and an even tinier fraction tor the eight to twelve or more large masks commonly required to accommodate 

several kinds of printing medium, several print speeds and so forth. 

r0126l The present invention can be used to generate masking for an image even while the .mage is being printed, 
and « desired the mask can be a major fraction of the image dimensions. In this case the effective data compression rs 

jnpiSy ^Ltiyj error hiding -A printmask also can be generated so that it does not use nozzles that are not working 
properly, or uses them sparingly and in well-defined conditions, optimizing the usage of the rest of the nozzles. In addi- 
tion even image type and other dynamic conditions can be accommodated. ^««,ii ino 
[0128] Printers with sensors capable of analyzing the "quality" of inkjet pens nozzle by nozzle (such as the optcal line 
55 sensor used in most large-format printers) should be able to generate printmode masks internally, taking advantage of 
the current state of the pens. Nozzle quality includes nozzle outs, but extends to weak or misdirected nozzles. 
[01 29] The present invention encompasses weighting the use of individual nozzles. Therefore a designer can straight- 
forwardly derive an auxiliary algorrthm which uses the printer's assessment of each nozzle to generate constraints to 
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the principal algorithm described in this document. 

[0130] These constraints, ordinarily, decrease the weights assigned to weaker nozzles. The printer then runs the algo- 
rithm with these new per-nozzle constraints along with the existing general constraints for the printing medium, writing 
system, etc. to generate a new printmode. 
5 [0131] With this approach, and the core of the algorithm in the f irmware (it isn't large), printmode masks can be gen- 
erated internally and dynamically after every pen check, for best output. The writing-system designer should ensure 
that pen servicing is attempted automatically before falling back to printmode changes. 

[0132] Additionally, limits should be placed on the minimum number of working nozzles, or minimum weights each 
nozzle is using, before informing the customer that the pens must be replaced for acceptable throughput or print quality. 
w [0133] Even relatively inexpensive printers can use the present invention to provide error-hiding print modes. For 
example, employing acoustic drop detection tor each nozzle, and the algorithm described in this document, users can 
be offered the option of extending the effective life of a print cartridge without loss of print quality by using slower, but 
error-hiding print modes. Some additional considerations follow. 

is (a) Detailed nozzle state — A list of nozzles that are inoperative ("dead") is straightforwardly used as a constraint 

to a printmask design. Such an arrangement enables the design process to adapt to known initial nozzle outages 

encoded into the pen at the factory, and changing conditions of the pen as well. 

If the printer is able to detect also misdirected or weak nozzles, as noted above this information can also be 

used to minimize and condition the usage of these nozzles. This scheme allows a much higher-quality hiding of 
20 errors than traditional strategies, which are based on static lookup tables (LUTs) of nozzles to use for backing up 

each particular nozzle that may fail. There are at least three main benefits: 

(b) Mask integrity — The mask retains its texture and other main characteristics. There will be no noticeable loss 
of quality, as long as there is a chance of backing up the dead nozzles at all. (This process does have limits: if there 
are enough dead nozzles, no backup is possible; and at an intermediate level of nozzle failures the system through- 

25 put may be so low as to disfavor continuing to print, or at least to disfavor starting printout of a new image.) 

(c) All able nozzles used for backup — First, in event of a dead nozzle, all the nozzles which are able to back it up 
can be made to share that responsibility. If a nozzle which night be on a static backup-nozzle LUT also fails, the 
whole LUT approach is seriously degraded — but with adaptive error hiding the system rearranges ail its resources 
to accommodate whatever combination of failures actually occurs. 

30 (d) Malfunctioning nozzles redeployed — Second, a nozzle that is misdirected or weak but not inoperative can still 
be used to the extent its condition makes reasonable. For instance such a nozzle may be used with particular 
weights that disfavor repetitive functioning in consistent positions within a swath, so that the nozzle adds to inking 
but does not significantly contribute to swath-edge banding. 

(e) Job type — In addition, mask generation can be made to depend straightforwardly upon known image charac- 
35 teristics such as a user could enter on the printer console or in a computer interface, or image types such as a 
printer driver can extract for itself from the types of objects incorporated into an image. A particularly powerful spe- 
cial case of adaptation to job type is discussed in the next subsection below. 

[0134] Imaae-dependent masking — Given the ability to build the mask on demand, it can be optimized to better 
40 match the type of file to be printed. This capability is not limited to the classical divisions such as commercial graphics, 
text, and photograph-like continuous tone images such as discussed in the preceding paragraph, but can also be made 
to depend upon more-sophisticated monitoring of image characteristics by the printer or its driver. 
[0135] Such design criteria include the activity of the image, and the number of high-density areas. By "activity" here 
is meant the number of changes per unit area seen in a data stream representing the image. 
45 [01 36] For example, a picture of a garden with grass typically has a high level of activity, as thus defined — constantly 
changing along pixel rows or in practically any other monitoring sequence: dark green, then light green, next black, and 
light green again. A simple green area fill or typically a picture of the summer sky has low activity. 
[0137] The degree of randomization of a mask has two important secondary effects: 

so a) The best-known characteristic of a random array is the lack of repeatability of whatever is done with it. If H is used 
to print whatever error is present in the printer or pen (misdirections, dead nozzles) will not be applied in a consist- 
ent way. 

As a result the printing process will not produce regular artifacts. This makes the process very robust in its abil- 
ity to suppress the conspicuousness of banding. 
55 b) It is perhaps less well recognized that the more random an array is, the more granular it appears. This is almost 
a natural law, which holds for any array of numbers. 

If it were possible to make a completely random array, it would contain areas with similar numbers close 
together, and areas where they almost no such pairings appear. This has an important implication when such an 
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array ol numbers is then used to put dots on paper: 

If the system is printing an area fill and the mask is granular, it prints dots very close to each other n certain 
axeas and S away S, othe'r areas. Where the dots are close together, the ink coalesces and stands out from the 

Othe o r ^ olhi E2 ^«22X Printing an area with high activity, even though the inks are still actually 

5 * is not conspicuous - as * e variation in ima9e detai,s evWent,y 

disrupts the coalescence that produces a blotchy appearance. 
Thus in the abstract it is desirable to make masks random, but in practice rarulom masks produce blotchy r^uttsin area 

Snf*^^ 

areas makes the result prone to objectionable coalescence and granularity, and so should be avoided in favor ot a less 

„ Z%T^e^Z^^ masks to appear very granular and to produce highly granular images when 
SSL pr^t mtdtone La-fU? fields can be appreciated by a graphical example. Tne example will also demonstrate the 

^tZ^^S^ons of three 256x256-pixe.. 24 pixeUmm (600 dpi) pnntmasks. in 
K pass 'numbet are^ rn^nto distinct respective gray levels. The only difference between these three views is 
2 o ^ deSS oTr^dTmness dialed into the mask-generation process by setting of the constra-nte as deserved earlier. 
rai4i? Th^ 28 r 3 conspicuously ordered printmask. Ffe. 29 a printmask of high rarKlomness^ a* Fig. 80. 
nri^nL that is at imermediatepoint in the determinism-randomness spectrum. The high degree of patterning seen 
K Z T££l M res d*erministic. repetitive processes that occur in mask-building with the present inven- 

25 ^Tn^^ "rTSrrienS 
when the ImSL are used to print. The latter can be seen by convolving each mask wrth a midgray tone, as presented 

mi^rSia" 28^m F S rend^mSray tone that is so strongly and elaborate* patterned as to resemble 
T^e^^lT^X^y randomized mask renders the same tone with only a relative* resdua. 

£!? tS2 appears primarily as horizontal sequences of coarse, irregular dark spots. Tne F,g^ 

r<S*SSS HI Sg boffi raafcel, small granmanty and at leas. relaMy wxx^cuous £ now 

S^Th^aS o«<»eotthlslaainic«jelat° maBhinemnctoiiness levallo Image caracKmlKS. andthe'mege 

be better. 

11. OPTIMALLY SIZED MASKS 

Sl^rlS in particular maKng printmasks the size of the pen or large, has been shown to 
was^bs£ved^^ 

much 1 ZSm than uSd now. Present implementations appear able to do roughly the same while also en.oy.ng a 

LeSSSS.cies) and loses sensitivity outside this range. Viewing distance plays an .mportant role, 
uo o K^iSS taSSS «. see minuscule defects, and beyond this distance such defects are ess visible. 
£150] t hTs bSoT^a; making a printmask width between VA and 2« cm <^£^)£ZZ& 
mum banding-concealment performance. If masks are smaller, the repetitive pattern falls into the range of frequences 



30 



35 



40 



45 



50 



55 



20 



BNSDOClD <EP 0990528A2 I > 



EP 0 990 528 A2 



that are easily perceived by the human eye. 

[0151] If masks are bigger, remarkably enough, little additional benefit is achieved. This discovery is extremely valu- 
able as it enables restraint of mask sizes at about 2V£ cm without significant loss of quality. 

[0152] It will be recalled that intuitively those skilled in the field would expect significant benefits from mask sizes 
ascending to a major fraction of a full-page image width. Thus the observations described above yield a surprising and 
powerful result. 

[0153] Humans have typically a very strong response to stimuli varying at about five cycles per degree, which corre- 
sponds to roughly 1 .2 cycles per millimeter (thirty cycles per inch) when viewed from 250 mm (ten inches). At only mod- 
estly increased frequency, up to eight cycles per degree, the response is only about ten percent of that at five cycles. 
[0154] Considering the response to fall off comparably at lower frequencies, and geometrically, at about 0.04 cycles 
per millimeter (one per inch) the response is extremely attenuated. If a person looks at a 0.04/mm pattern close up 
(assuming ability to focus at short distances), individual defects may be quite visible, individually — but, because the 
repetitive character is lost at the lower angular frequency in the close-up view, the defects tend not to appear noticeable 
as a pattern. 

[0155] Resolution relation to mask size — In accordance with the above discussion, optimum printmask size must be 
stated in terms of printed physical size, and therefore may be seen as dependent on the printing resolution. More pre- 
cisely, in terms of absolute dimensions the mask size is independent of resolution — but if it is defined in tens of pixels 
the optimum mask size varies generally with resolution. 

[0156] If the printing resolution is 24 pixels/mm (600 dpi), a mask that is 512 bits wide will be approximately optimal 
in size. If the printing resolution is 47 pixels/mm (1200 dpi), the same quality will be achieved with a 1024-bit mask. 

1 2. NOZZLE-MODULATED PRINTMASKS 

[01 57] Ramp-dow n of nozzle usage at pen extremities — Defining a ramp of nozzle usage at the end of the pen that 
first reaches the printing medium has been shown to significantly improve the quality of the output on many media. If P 
is the height of the medium advance, expressed in nozzles, the ramp is typically made to extend over a number of noz- 
zles equal to or smaller than R 

[0158] Within that condition, selection of the ramp length is readily determined by limiting the ramp to those nozzles 
that will find the printing medium moderately dry. Beyond that point the image-quality significance of partial ys, full inking 
tends to be attenuated, because small additional increments of ink are less conspicuous on an already damp sheet. 
[0159] Best results are often achieved with linear ramps, with the first nozzle printing perhaps only one percent of its 
.normal usage. The Pth nozzle prints one hundred percent of the normal usage, and the intermediate nozzles follow a 
linear scale between those two percentages. 

[0160] Other ramp patterns such as quadratic, cosine, or arbitrary monotonic can serve as well. In any event prefer- 
ably the remaining (Lg, central) nozzles print slightly over one hundred percent to make up the dots not printed by the 
first nozzles. 

[01 61 ] Different weighting schemes may be used for different media. Some media accept the ink so well that the result 
almost always look good regardless of weights. Other media simply change their properties when they are wet, so that 
the second pass in a given area looks different from the first. Many intermediate behaviors are seen also. 
[0162] Defining a usage ramp with the leading nozzles allows a smooth transition between passes, instead of the 
abrupt transition that occurs in previous approaches, and so is less prone to banding. In principle the invention encom- 
passes raping the usage of trailing nozzles as well. 

[0163] In practice, however, the leading edge of a pen finds the printing medium dry, while the trailing edge often fires 
over an ample amount of ink already deposited. Experimentation has suggested that more-important improvement can 
be achieved by ramping at the leading edge. 

[0164] Sawtooth modulation within the nozzle array — This is another good way of modulating the usage of nozzles. 
It can be especially advantageous in decreasing the usage of the most important so-called "sea nozzles", which are the 
first nozzles to touch the media and each group of nozzles that is near a multiple of the paper advance. 
[0165] Among these, the most important are generally the first three groups: the first to touch the media, the nozzles 
near P and the nozzles near 2R Strictly speaking, however, the modulation need not be periodic — and in fact some 
advantages may be gained through use of a spatial variation that is arbitrary, or random-appearing, or both, or that 
superimpose these characteristics upon a generally periodic variation. 

[0166] Waw seam — Another strategy for nozzle modulation that reduces banding consists of using the nozzles une- 
venly along the width of the mask. This approach can be implemented in a variety of ways. 

[0167] For example, masks can be designed to vary the usage of only the first nozzles to fire ink on the medium, com- 
pensating for this uneven coverage throughout the rest of the mask. Alternatively the final nozzles to print on the 
medium can be made to compensate exactly for the variation of the first nozzles, or these trailing ones can be made to 
vary independently. 
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[0168] Morespec^ny.^ 

mask maps to the nozzles that w,ll f .re wk hrst ^"J^g^SSSr as in a conventional mask. 

M sections along the horizontal (scan) ax* .nstead of treating h.s * ^ density it 

[01701 iiyM^' " g^S Tarea toa^S or completely different among 

the hue shift considerably, particularly when printing bidirectional^, 
is 13. ACCOMMODATION OF OTHER ALGORITHMS 

[0 172] The present implementation of the invention includes a program prepared in the we!.-known computer ,an- 
guage called "C++". The program has been dubbed shakes D .intmasks using a seH-standing input text 

?0173] It establishes an automatic method for generating and empl m I Pff ^ fl|norithm . ^ough 
He - called an "NSP file" - of mask constraints, and ^"■^JSPSXTE asVepresTnting the phrase 
^S^S^^^X^ S" V th b e NSP file to gu.e generation of a 
mask .. am .„ ^ , anauaae called "NSP" that is used to represent what a writing- 

40 the mask-generating procedure. onaWo c whoiiv different analytical or relational modules to be 

[0179] What makes this decoupling signrteant is ^^^^l^ZenXors and discussed in this doc- 
plugged into the program, including some that have been so to developed. This can be done with- 
ument-and also including others that may be ^V^^^^^ZZiS^ handle low-level mask- 

<. ^m^s^e^^ 

S^Tp^ 
50 J^^SETTc^^ 



20 



25 



30 



35 



55 



return the mask size, and so on NS Pbase (Fig ) and basicMask. Each box in the drawing is a class; 

[0183] SMkgs has two base classes, entitled NS Pbas 3 o1 ^ other class . -me anows them- 

a class with an outward arrow pointing at another class is safl to to me par* i 
selves also signify the inheritance of properties or character.st.cs from the parent. 
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[0184] NSPbase defines the idea of a syntactical construction that could be found in an NSP file, and what to do when 
you find it. For example, a syntactical construction might be: 

matrix sample__matrix 

5 

{ 0 2 0 } 
{1X0} 
{ 0 0 0 } 

10 

endMatrix 

An NSPbase object understands that there is a unique word that defines its start and end, in the case above, those 
words would be "matrix" and "endMatrix." 

is [0185] NSPbase, however, is an abstraction; it provides no functionality for doing anything with objects it reads. From 
NSPbase inherit (note its two outbound arrows) the abstraction of a top-level weighter and a top-level mask. By "top- 
level" is meant that these objects appear as such in the NSP file; they are not contained within any other object. 
[0186] The only kind of top^vel weighter is a "matrix," as shown earlier, and corresponding to the NSPmatrix class 
in the drawing. This allows the user to use one matrix while constructing several masks. 

20 [0187] Top-level mask objects are where there begin to appear what may be called "hooks" for connection of modular 
objects such as discussed above within the present section. As the drawing suggests, there is the general idea of a 
mask; in practice a mask has a width, height, number of passes, and the ability to read and write to its data. 
[0188] From "basicMask" comes "NsPuserMask", and then the specifically implemented NSP syntactical construc- 
tions "greedyMask" and "evalMask" The "evalMask" class provides the idea of evaluating a generated mask for its com- 

25 pliance with the specified constraints. 

[0189] From this in turn comes the "optiMask" class, which uses an evaluation algorithm of evalMask — in conjunction 
with exploratorily developed changes to the generated mask — to look for ways to improve that originally generated 
mask. 

[0190] A first category of "hooks" is thus the NSPuserMask class, from which the currently used greedyMask mask 
30 generation algorithm inherits. The greedyMask algorithm relies principally on spatially oriented constraints. 

[01 91 ] As will be clear from the foregoing, shakes was designed for the idea that other classes could inherit from the 
NSPuserMask class. The first applications of this potentiality are other mask-generation algorithms. 
[0192] A second category of hooks is the evalMask class. In a manner analogous to inheritance of mask-generation 
algorithms from NSPuserMask, a variety of mask-optimization algorithms can inherit from evalMask. 
35 [01 93] Exemplary of a third category of hooks, at the smallest scope and within the greedyMask algorithm specifically, 
new kinds of weighters can be added to this algorithm. At present, the greedyMask algorithm can consider the values 
of cell neighbors, the relative quality of the nozzle that would be used for the current cell, the distribution of nozzle 
usage, and several other factors. 

[0194] Nevertheless, shakes is also well prepared for the idea of adding a new weighter (a NSPuserWeighter class 
40 exists to enable this) to the greedyMask algorithm. Indeed, greedyMask began with only the matrix weighter. and now 
includes at least eight ways to affect its behavior. 

[0195] These include the keywords "matrix", "constraint", "list", "nozzlesDistr", "parityMatrix", "compensate", "random" 
and "rotate". (Certain of these are established in the "mask" top-level syntactical construction.) 
[0196] Bearing in mind these ideas about the built-in adaptability of shakes to variants, the sections below discuss 
45 several such variants — including not only dither masking but also optimization of already-completed masks and gen- 
eration of composite masks. Also discussed is a variant that is ideally implemented through a somewhat greater degree 
of program modification, namely on-the-f ly mask generation. 

14. ACCOMMODATION OF SECOND-PASS OPTIMIZATION 

50 

[0197] In like manner, preferred embodiments of the program aspects of the invention have been made to accept a 
modular orintmask-optimizing control algorithm. Such an exchangeable module receives a fully-generated printmask 
as an input. 

[0198] The optimizing control algorithm reprocesses that received printmask to substantially optimize it for image 
55 quality. The term "substantially" is used here to allow for the fact that optimization is actually in itself a relative concept, 
in which quality is traded off against time and expense at some rational rate of exchange. 

[0199] This optimization process is enabled by the presence of its parent, the evaluation algorithm. As suggested 
above, the optimization procedure exploits the evaluation algorithm as a tool — Le^ its assessments are used to deter- 
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mine what progress and eventual level of success are achieved by the optimization. 
15. COMPOSITE PRINTMASKS 
. lmm Thspartotthe^nen,™ 

"l!££r P -TO S discussion relates to arateoies thai allow a computer program to buM a priremask that hiMs os-Bin 
(0201) TOs ure)ertvi " » i8 assum ed that the designer knows what taquirements the mask 

the distance in number of passes to a value already present .n any g.ven ne.ghbor. For .nstance. .n NSP format. 



75 



20 



25 



30 



35 



40 



45 



50 



55 



24 



EP0 990 528 A2 



w 



15 



constraint name 
■ . default 1.0 # All candidates are welcome by default 
(-1*0) # previous pixel in the same row 

[0:0.0] # Values at a distance of 0 in number 

# of passes (equal values) are forbidden 
[1:0.1] # Values at a distance of 1 in number 

# of passes weighted 0.1 (not desired, but 

# accepted) 

(0,-1) # the neighbor one row up 



[0:0.5] 



# Equal values weighted 0.5 



endconst raint 



This weighter will assign a weight to ail possible candidates, for any given position, taking already present neighbors 
20 into account. This constraint can be applied to the shaded, empty position of the following mask. 
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The previous pixel in the same row is assigned to pass eight. This means, applying the constraints defined for (-1,0), 
that eight will be weighted zero, and seven and one (both at a distance between one and eight inclusive) will be 
weighted 0.1. 

[0212] The upper neighbor is seven. Applying the constraint defined for (0,-1) will give a weight of 0.5 to the candidate 
seven. But there was already a weight for the seven, so a combined weight has to be calculated. None of them is zero, 
therefore an average is acceptable. The list of candidates after weighting is: 

[1 : 0.1], [2 : 1.0], [3 : 1.0], [4 : 1.0], [5 : 1.0], [6 : 1.0], [7 : 0.3], [8 : 0]. 



The final meaning of those numbers is: eight is a forbidden candidate; one is the worst choice between the legal 
options; seven is better than one; and two, three, four, five and six are all preferred choices. The function that picks a 
value chooses randomly between these equally preferred choices. 

[0213] The constraint matrix as a weighter — The constraint matrix presented earlier in this document is a subset of 
45 the naghborhood constraint introduced just above. It can be regarded as a weighter in which every weight is either 0 or 



1. 



[0214] rt has been retained as a legal weighter because, even though all that can be done with a constraint matrix can 
also be done with a neighborhood constraint, the constraint matrix provides a more concise and graphic way of repre- 
senting restrictions. The syntax proposed for the constraint matrix is: 



matrix name 



55 



{0010} 
{0121} 
{11X1} 
{0010} 
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endmatrix 

Here the X represents the pivotal point of the matrix. 

[021 5] Building a flat ma sk Quality. Of the mask — Flat masks are those in which just one drop is to be pnnted for each 
5 pixel This is the case of the mask for one color in a noncomposite printer. 

[021 6] Here is a way to build such a mask: begin at the upper left corner of the mask, and fill in row by row. For each 
position, let all the weighters assign a weight to each candidate. 

[021 7] Each weighter will be multiplying the weights it is supposed to assign by a relative weight, also defined by the 
user, that represents the relative importance of a weighter with respect the other weighters acting. When all the weights 
10 have been assigned to each candidate, they are combined into one weight per candidate. 

[021 8] After that the choice can be made, for which a couple of options are implemented. One is picking the candidate 
with highest weight (if more than one has highest weight, randomly pick one among them). The other option is using 
the weights as probabilities and picking one in such a way that the probability of being chosen is the weight. 
[021 9] Once a candidate has been chosen, its weight is a good measure of how good the option is. Therefore, aver- 
aging the weights of all the candidates chosen while building a mask is a measure of how good the whole mask is. 
[0220] In other worcls, given a certain set of weighters, the best mask is the one that, when applying the weighters to 
all its values, will give a highest average. This average will be called Quality of the mask, and it is meaningful only 
referred to a certain set of weighters. : 
[0221] Being able to calculate a quality for the mask is very important for the previously mentioned feature of optimiz- 
ing the mask generation. Given a measure of how good a mask is, it becomes possible to find algorithms that will opti- 
mize it. 

[0222] Syntax for the "™sk declaration — One example of a very simple syntax for defining a mask is — 
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20 



25 
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mask name 

define { 

size (32, 240) 
passes 8 
} with { 

weighterl 1.0 
weigh ter2 0.8 



35 



} 



endmask 



40 



45 



in which yyejghied and weighted are names of weighters defined before in the program. The number after each name 
( i, e .. 1 .0 or 0.8) is the relative weight between them. That is, here the designer is giving more importance to wejghterl 

[0223J W uSng e ^lat m^k as a reference while buildi ng another mask — It will now be clear that more than one weighter 
can be acting while building a flat mask; it is also important to note that some of those weighters can be "looking" at 
other masks rather than the one being built. As an example consider a mask, that can be either read from disc or just 
built. The mask is: 
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[0224] It has been built to satisfy the constraint matrix: 
matrix matrt 

5 

{00 1} 
{011} 
{ 1 1 X} 

w 

endmatrix 

The syntax used for building it has been: 

mask magenta 

define { 

size (5, 5) 

20 passes 8 

} with { 
■ • matrl 1.0 

} 

25 endmask 



Consider that this first mask is, for example, the mask for a magenta pen. Next assume that it is desired to build a mask 
for a yellow pen, and that the yellow-pen mask should fulfill the same constraints that the magenta mask does — but 
30 also that it is not to fire at the same time that the magenta pen fires, and furthermore that no pixel of the yellow mask is 
to fire when the upper neighbor has been fired by the magenta. 

[0225] All these "desires" can be expressed as: the mask has to fulfill matrl applied to itself, and the following neigh- 
borhood constraint applied to the maaenta mask: 

35 constraint crt1 

default 1.0 
(0,0) [0:0] 
(0.-1) [0:0] 

40 

endconstraint 
The syntax for declaring the yellow mask would be: 

45 mask yellow 

define { 

size (5, 5) 
passes 8 

50 

} with { 

matrl 1.0 

crtl 1.0 to magenta 

55 ) 

endmask 
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A resulting mask is: 
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[0226] At this point a representative next step would be to build a mask for a cyan pen that fulfills matrt. crt1 applied 
to maaenta. and crt1 applied to yellow. 
15 [0227] It has been suggested that applying a neighbor constraint to a different mask is useful not only for restricting 
a mask with the values of the reference mask, but also to "copy" another mask. Suppose for example, that a neighbor- 
hood constraint such as — 

constraint crt2 

20 

default 0.1 
(0,0) [0:1.0] 

endconstraint 

25 

is applied to the magenta mask as reference for building another mask What it will do is consider the values in the ref- 
erence mask as preferred choices: it will copy it. 

[0228] It may not be worthwhile to copy the particular mask discussed as an example above, but this same procedure 
can be applied to a mask with a certain desired texture as reference. It is possible, then, to make a mask that fulfill cer- 
30 tain restrictions, on one hand, and will try to copy a desired texture, on the other. 

[0229] Rotating masks — A very simple technique to produce a mask from a reference that will never fire at the same 
place that the reference mask does is "rotating" the reference; this is, adding a constant using modulus arithmetic to all 
the values of the reference mask. 

[0230] Low density masks — It is known to use a mask that produces densities of ink different from one hundred per- 
35 cent. For example, in certain cases it is useful to print just ninety percent of the pixels, leaving the others blank. 

[0231] The current invention provides a new way to do this, namely by using a reference mask as a dithering matrix, 
and decide whether or not to print a pixel depending on the value in the dithering matrix. A zero in the mask will mean 
not to print the pixel. 

[0232] This reference mask can be of any size, and any number of passes; and any dithering matrix can be used. The 
40 syntax used is — 

mask notFull 

define { 

45 



50 



55 
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size (5, 5) 
passes 8 
} with { 

matrl 1.0 

crtl 1.0 to magenta 

} 

density 90 with dither 
endmask 



75 in which dither is a mask that has probably been read from disc. The building of masks of more than one hundred per- 
cent density will be explained below. 

[0233] Composite masks — These are masks in which more than one drop can be printed for each pixel. This is the 
case of the mask for one color in a composite printer. 

[0234] A composite mask will be made by adding up different flat masks, that will be called layers. The way it works 
20 is simple: when just one drop is to be printed in a certain pixel, the printer looks at the first layer and will find there in 
which pass the drop has to be fired. When two drops have to be printed in a certain pixel, the printer will look at both 
the first and the second layers and will fire at the two pass numbers found there. 

[0235] The ability to build flat masks constrained by other flat masks is crucial for building a composite mask. The 
preferred strategy is: build the first layer (or "plane") with whatever constraints it has to fulfill; then build the second layer, 
25 with the desired constraints it has to have by itself, and the constraints that it has to respect related to the first layer. 
[0236] The third layer will have to fulfill interlayer (or Interplane") constraints with the first two layers. Such interfayer 
constraints are commonly related to physical limitations of the printer. For example, most printers cannot fire two drops 
in the same pixel in the same pass; this condition directly translates to a neighborhood constraint that all the layers must 
.. fulfill between them. 

30 [0237] This approach is reasonably general, and with the weighters already implemented enables the building of 
masks for composite printers. One weighter that should be added to the arsenal, and which is readily implemented, is 
this: given a number of flat masks, keep the number of times that a pixel is fired in the same pass under a stated max- 
imum value. 

[0238] As the complexity of a mask-building task increases, satisfactory solutions become more difficult to find, ft is 
35 easy to build a four-layer printmask that will not fire the pen more than once in the same pass, and that will also fulfill 
simple constraints if it must be printed in eight passes — but if the number of layers too is eight, there will not be many 
choices for the last layer. 

[0239] Syntax — In the present invention, the syntax implemented for building a composite mask is just an "addlayer" 
command. For example, to build a two-layer mask from the example masks discussed previously, the NSP syntax is — 

40 

mask compos iteExample 
addlayer 

magenta 

45 yellow 

endinask 

and the output would be (this time, I present the result with the format we are actually using): 

50 

size (5,5) 
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passes 8 
layers 2 

5 8 6 12 
3 15 4 8 

6 5 4 7 5 
13 7 2 6 
5 8 16 3 



6 14 2 7 
2 4 3 8 4 

is 8 3 15 3 

5 6 8 4 2 

7 2 3 7 1 



20 



[0240] Fvam plftNSP file -Here is a specimen of a simple text file for use in defining mask requirements: 

25 # Mask Definition Language (NSP) Example 



WEIGHTERS 



30 # T his is the old constraint matrix. The name will be "matrix", 

# in order to distinguish it from the new constraint concept, 

# explained below, which does not have a matrix form. The matrix 
« does not really accept weighting: it will just put 0 or 1 . 

# It can be thought as a shorthand for the generalized constraint, 



35 



matrix matrl 
40 {0 0 0 0 } 

{0010} 
{0 0 2 1} 
{01X0} 
{ 0 0 0 0} 
endmatrix 



45 



so 



# This is the extension of the constraint matrix. It is possible to 

# assign a set of weights to any neighbor. 



constraint crtl i The name is mandatory 
5 5 default 0.1 

(-1,0) # The previous pixel in the same row: 
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[0:0] 



# equal values (difference = 0) forbidden 

# values within a distance of 1, weighted 0.8 

# values within a distance of 4, weighted 0.1 



11:0.8] 
[4:0.1] 



(0,-1) 



# The upper neighbor: 

# equal values weighted 0.1 



[0:0.0] 



endconstraint 

constraint crt2 

default 1.0 

(-1,-1) [0:0.2] 

(-2, -2) (0:0.1] 
endconstraint 

■•.*.- . ■ 

constraint intermask 
default 1.0 

(0,0) [0:0] # no equal values in the same place 

endconstraint 

# Read the dithering matrix for less than 100% density from disc 
mask dither 

read dither. pgm 
endmask 

The first layer is read from disc 
mask firstLayer 

read maskOrg.pjm 
endmask 

# The second layer is built upon the first 
mask secondLayer 

rotate firstLayer 5 
endmask 

# The third layer is actually filled following some constraints 
mask thirdLayer 



define { 



size (16, 15) 
passes 8 



# (X, Y) -> (Columns, Rows) 



> with ( 



intermask 1.0 to firstLayer 
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crt2 1 0 # if the "to" command is missing, 

# the weighter will apply to the 

# mask being defined 

matrl 1 

} 

# Following commands are optional in the building of 

# the mask. They control seeds, and different options that 

# give different textures for the same constraints. 

t5 #getseed prb.seed 

putseed prb2 . seed 

tpasswrap # pass number 5 plus 4 gives 1 in an 8 pass 

# print mode 



10 



25 



30 



#random # use weights as probabilities 

compensate 1.0 # compensate the odds of less favored choices 
#density 25 with dither 
endmask 

35 # Build a composite mask from the layers already defined 

mask maskAll 
addlayer 

f irstLayer 

40 

secondLayer 
thirdLayer 

endmask 

45 

# Output it to disk in different formats 
output maskAll to maskAll. pj™ 
output maskAll to maskAll. pg™ in pgm 
so output maskAll to maskAll. pnm in nozzles 240 40 



55 16. DESIGN OF COMPOSITE PRINTMASKS 



[0241] The discussion next proceeds to a general notation for composite printmasks. and a method for applying the 
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constraint-matrix analysis. 

[0242] Notation for composite masks — The notation for the mask is an extension of the notation for single<lrop 
masks. In a single<Jrop mask, each pixel is associated with a number that represents the pass number in which that 
pixel is to be printed. In a composite print mask, this single number is replaced by a triangular array of numbers within 
5 a square matrix — or, as a verbal shorthand, a "triangular matrix" — that will be called a "cell". 

[0243] The cell defines which passes will print for each amount of drops to be fired. The number in row 1 of the trian- 
gular matrix is the pass number that will fire if just one drop has to be printed. 

[0244] The m numbers in row m define which pass numbers will fire if m drops have to be printed. An example will 
show how it works; in a three-drop-per-pixel (3 dpp) mask, a cell such as shown in Fig. 34 means that: 

10 

a) if only one drop is to be printed for this pixel, it will be fired in pass number one; 

b) if two drops are to be printed, they will be fired in passes number two and three; and 

c) if three drops have to be printed, two of them will be fired in pass number one, and the other in pass nurrtoer two. 

75 [0245] Example of a mask — With this notation, the mask is a group of triangular matrices, each one associated with 
a pixel on the paper. For example, this could be part of a three-drop-per-pixel, eight-pass mask: 
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35 

[0246] Restrictions in the for m of the cells — Setting d as the number of drops per pixel, the number of potentially 
different pass numbers that are needed to fill a cell is (d/2)(d+-1). This number grows rapidly with the number of drops 
per pixel; for example, for a four-drop-per-pixel print mode, ten potentially different pass numbers are needed to fill a 
cell. 

40 [0247] This means that if the number of passes is low there is no chance to fulfill any constraint at all between neigh- 
bors. Following the same example, if the number of passes is eight, the odds of having ail eight numbers in one cell are 
high, if no restrictions are applied within the cell, and then it is not possible to find a neighbor that does not fire in the 
same pass number. 

[0248] Restrictions within the cell can be applied just by forcing the form of the cell. In a three-drop-per-pixel mask, 
45 for example, two valid alternative choices appear in Fig. 35. 

[0249] In both cases, the number of potentially different pass numbers in each cell goes down from (d/2)(d«-l) to & 
which makes much easier the finding of masks that fulfill constraints between neighbors. The combination of both would 
lead to an even more restricted ceil, in which all the drops would have to be fired in the same pass. 
[0250] This kind of format restriction should not be regarded as something necessary to the system. It is just a con- 
so venient way to reduce the degrees of freedom of the problem, and thus to make it better constrained. It can also be 
thought as something to keep the pen from firing at impermissible frequencies. For example, for a pen that can fire up 
to four drops in a pixel at one given pass, but that has to print eight drops per pixel, a possible form for the cell appears 
in Fig. 37, subject to the condition in Fig. 38. 

[0251] In Fig. 37 all the £s in each row are a respective common number for that row. but this condition is not man- 
55 datory. A less restrictive but still valid form of the matrix requires neither all the same c's in a row nor all the same d's in 
a row, but rather only that all the d's in each row must be different from all the c's in the same row. 
[0252] The form shown, however, is more restrictive and leads to a better-conditioned problem. Another valid way of 
restricting the problem is a matrix in which all the £s are the same, and all the d's are the same, with the only condition 
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of d different from c. This would lead to a cell with just two pass numbers to fill in, and thus to a mask very easy to fill 
— and yet fulfilling constraints between neighbors. 

[0253] Applying a constraint matrix to a composite mask — The constraint matrix should be applied exactly in the 
same way as for a single-drop mask, but extending it to all the numbers in the neighbor cell. Say, for example, that the 
5 constraint matrix of Fig. 39 is to be respected, and it is desired to find the missing cell for this mask: 
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Applying the constraint matrix, there would be a one in the upper neighbor, and this would forbid options three, one and 
20 six, and a one in the left neighbor, and this would forbid options three, five and eight. Therefore, options one, three, five, 
six and eight are not allowed for this ceil. A valid choice would be: pass number two for one drop, passes number two 
and four for two drops, and passes number two, four and seven for three drops. The finished mask would be as follows. 
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[0254] Formal approach — This section will give a more formal treatment to what has been presented in the previous 
section at an example level. 

40 

(a) Cell — A cell is a triangular matrix, associated with a pixel in the plot, whose components are natural numbers 
ranging from unity to the number of passes, qE The p numbers in the row p of the cell are the pass numbers in 
which the printer will fire if p drops have to be printed in this pixel. The general format of a cell for d drops per pixel 
appears in Fig. 40, and the maximum number of different values in it is the larger of: 

45 

m the number of passes and 
■ (d/2)(d+1), 

if no restrictions are applied in the form o1 the cell. 
so (b) Mask — A mask is a rectangular (usually square) array of cells, each one associated with a pixel in the plot. The 
mask can be either the size of the plot (a run-time designed mask, for example), or a smaller size, in which case it 
must be tiled to fill the plot. 

It has the general form appearing in Fig. 41 . Its elements (cells) will be referred to as m, c , where t c have the 
usual meaning of row, column (both starting at one). 
55 (c) Constraint matrix — The simplest way to define neighborhood restrictions that the cells on a mask should fulfill 
is the constraint matrix, as defined earlier. The general form of a constraint matrix is shown in Fig. 42, where X is 
the pivotal point, and the number ^ j means: for any given position ic of the mask, all the elements of the cell C f,c 
are not within the sets defined by the open ranges: 
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15 i.m-[\>i>9. i.m + [ij[ for all Km. 

(d) Polar symmetric constraint matrix — It can be shown that restricting the form of the constraint matrix to that of 
5 Fig. 43 enables a much more efficient way of filling in the mask Essentially, if the constraint matrix has this form a 

building strategy of left-to-right, top-to-bottom need account only for the neighbors already chosen (the past) and 
the future options will automatically fulfill the constraints. Earlier discussion explains how this works, and the validity 
of the extension to composite masks can be shown. 

io 1 7. ON-THE-FLY MASK GENERATION 

[0255] With minor modifications the mask generation algorithm described above is extended to generate masks — 
even full-page printmasks — while printing (assuming processor bandwidth) with a minimum of memory usage. As in 
the form described above, the algorithm applies the matrix to the empty mask, scanning by row or by column until a 
75 mask is generated or the algorithm determines that the current mask cannot comply with the constraint matrix. (The lat- 
ter possibility, however, is preferably foreclosed in use of the invention for on-the-f ly mask generation.) 
[0256] This algorithm can be implemented in printer firmware, or in a driver or in ASIC structure. It requires a minimum 
of memory usage, dependent on the size of the image. 

[0257] The algorithm assumeg operation of the printing portion of the firmware on the basic principle that at least one 
20 swath of data is rendered in memory and available to print. A printmode so constructed may use any number of passes. 
[0258] In principle this approach can be used to generate masks the size of an entire printed page, even a meter 
square or more, by operating the program immediately before printing each swath. To accomplish this, it is desirable to 
save certain data from the previous swath, for use by the program in satisfying spatial and temporal constraints across 
swath boundaries. 

25 [0259] For use in a commercial product, it is desirable to do this with as little memory and as quickly as possible. To 
that end, it has been determined that it is possible to save only the last few rows, or even just one row. from the previous 
swath — since that is really all that interacts with the constraints in the NSP file. 

[0260] If a printmask is generated by columns, sweeping across columns of each swath, then the mask may be gen- 
erated — keeping just ahead of the pens — even while the printer prints each swath. In this case the mask for the whole 
30 swath need not be saved, and at most only a few kilobytes of data need be stored. 

[0261] Thus at each advance of a printing medium, as each new incremental portion of an image is rendered, much 
of the printmode remains the same and can be regenerated by using that saved data as a seed. The mask for generat- 
ing the incremental data can be generated in the same way. provided only that the previously-just-used mask data is 
treated as a given. 

35 [0262] Since the engine of the mask-generation algorithm is a pseudorandom number generator, all that need be 
stored to regenerate a mask in this way is the seed value and the constraint matrix. Consider again the previously dis- 
cussed simple constraint matrix alternatively shown as — 
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where a "Y" or gray square designates a neighbor that is a constraint on the pivotal point "X", and an M N W or black square 
designates a neighbor that is not a constraint. 

[0263] Consider again also that the mask in process appears as shown below — but now with the new understanding 
that the central, question-marked pixel is to print in the first row of a new swath , or in other words that the first two rows 
of the mask have been already been used in a previous swath. They are therefore unchangeable history, with which the 
system must reckon. 
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These first two rows of the mask were 
generated while printing the previa 
pwath . 



As may be recalled, the processing superposes the constraint matrix on the mask, using the saved data from the pre- 
15 vious swath to constrain the current swath as shown here. 
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For "X" in the mask as shown above, the only three values that come into play m constraining the value chosen for X 
are the numbers three and two in the row immedialfily above, and the eight to the left- 

^641 n other words the information in the top row is not necessary for determinate of perm>ss.ble values at X . 
Sample in this case of a three-by-three matrix only the test, row of a prev.ous swath ,s needed. 

Se sIviTo^nei of the n^sks for the next swam. H. as in the case shown above, only one row of data need 
be saved, then for example —for an E-size or AO-size page -this means: 

4 colors • 34 inches • 600 dpi • 1 bit/pixel • 1 row = 40.800 bytes. 

memory necessary to store a full page of data. 
18. HALFTONE MASK GENERATION 

rnttsm It should now be clear that the algorithm applies equally well to a printmode with four passes and one with ten 
S2L XXSZZ SSSd h ear.ier 9 portions oTthis document the present invention ateo encompasses creaton 

K_™12S3SS*fcn of "level" values within a multiple-level regime or MMonci 

T^as betTeZfferent printing passes). Making allowance for these differences of focus, basically the selfsame caJ- 

ilSSESSSSESSsSS 

itself to a very efficient and insightful exploration of solutions. 
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19. HARDWARE FOR IMPLEMENTING THE INVENTION 

[0270] Preferred embodiments of the invention operate in a printer 20 (Fig. 44) that includes a print engine 50 and is 
coupled to a computer 31 (usually a personal computer or workstation) that includes a printer driver 31 . Data 32 typi- 

5 cally resides in the computer, typically in some graphics application program, but often is partially developed or refined 
in the driver 31 — as is symbolized by the position of the data block 32 partially inside the driver 31 . 
[0271] The hardware of the present invention may most typically be a microprocessor and memory residing in the 
printer 20, operating in conjunction with the printer driver 31 ; however, in many cases the mask-creation capability 32 
and its target printing-control block 40 are distributed partially in the driver 31 and partially in the printer 20 — again as 

10 represented in the drawing by the positions of the blocks 32, 40 spanning the driver and printer blocks 31 , 20. 

[0272] The heart of the present invention is the mask-creation block 32, which includes a program memory that con- 
trols generation 34, 36 of a unitary dither mask 35 or a unitary printmask 37, or both. An effort has been made to sym- 
bolize the data-compression characteristic of the invention here by drawing the program-memory block smaller than 
each of the mask blocks 35, 37. 

is [0273] The program, however, actually controls generation of masks through the algorithm module 38, which resides 
in a part of the program memory 33. Much of the remainder of that memory is occupied by the NSP file discussed ear- 
lier. } , 

[0274] To enable the previously introduced adaptive features of the invention, the mask-creation block 32 receives 
inputs 28 of information 28 that has been encoded into or generated within devices 1 4, 1 5 in the several pens 53C, 53M, 
20 53Y, 53K (cyan, magenta, yellow and black respectively). The information encoding or generating devices report on pen 
dropweight, nozzle behavior, pen age and the like. 

[0275] The mask-creation block 32 also receives inputs 29 of information about the present printing medium 47. This 
information once again may be found from encoding or sensors at the medium. Such information sources relate to 
medium color 16 or type 17. or both. 
25 [0276] Further, devices 21-23 in the mask-creation block send queries 2V-23' to environmental sensors 1 1-13, to 
determine temperature T, pressure P or humidity RH. or combinations of these as desired. The sensors respond with 
the corresponding informational signals 25-27. 

[0277] When the image data 32 is processed through the dither mask 35 and printmask 37, output signals proceed 
to the printing-control block which issues commands 52C'-52rC to the respective pens for ejection of ink 54C-54-K to 

30 form an image 55 on the printing medium 47. The system down-stream of the printing control block 40 may be substan- 
tially conventional, or may be in part or wholly made up of new writing systems not now known. 
[0278] A printmask 37 generated by preferred embodiments of the invention is ideally rectangular or square (Fig. 45) 
with sides s = 1 Va to 2V& cm (0.5 to 1 inch) for the reasons previously explained. The diagram also represents a typical 
distance d corresponding to a spatial frequency to which human eyes are most sensitive, and as can be seen the two 

35 distances s, d are very distinctly different. 

20. OPERATION OF THE INVENTION 

[0279] The mask-creation block 32 of preferred embodiments of the invention, in addition to determining pass num- 
40 bers for deposition of desired inkdrops, also advantageously imposes a nozzle-usage ramp, over a distance E (Fig. 46) 
at the leading edge of each pen. A sawtooth distribution of nozzle usage, longitudinally of the pen, is also graphed in 
the diagram, together with a square-wave distribution of nozzle usage transversely. 

[0280] Preferred erribodiments also provide relatively offset masks mc (^9- 47) for the cyan pen C, for the 
magenta pen M, m Y for the yellow pen Y, and oIk for the black pen K. These offsets represent staggering effect men- 

45 tioned earlier, for purposes of separating seams. 

[0281] These several effects are preferably but not necessarily time varying. As noted previously those of the effects 
that represent underinking in some regions of the pen also are preferably compensated by overinking elsewhere. 
[0282] In operation for mask-on-demand performance, a first image may be loaded 61 (Fig. 48) into system memory, 
and the program operated to a dither or printmask, or both. The program is set, by restraining the number of constraints 

so in operation, so that — as long as the system is operating correctly — a mask is always produced 62 without fail. 

[0283] Mask creation is thereby started 63, and for the reasons stated earlier this is preferably accomplished on a 
column-by-column basis. In the process the system produces 64 a unitary dither mask , or creates a unitary printmask 
65. The significance of the term "unitary" here has been explained in an earlier section. 

[0284] The simultaneous operation of the printing procedure 66, 68, 71 and the columnwise mask creation 67, 69 will 
55 be clear from the diagram, for people skilled in this field, as a swath finishes 71 printing, the final row or rows in the 
swath are saved 72 to reinitialize 73, 74 both the printing and the mask creation, respectively, for the immediately fol- 
lowing swath. 

[0285] When the image is finished 75, if the printer-operating session 60 is about to end ( i. e.. if the machine will be 
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turned off), the mask or seed as preferred is saved 76 to nonvolatile memory. When the next operating session 80 
begins, the next image to be printed may be one calling for a s.m.lar mask. Drevi ously 

5 instead restarts 84 the original procedure shown at the ^^^V,^ in Fig 49 , n view of those earlier 
102871 Other earlier-discussed teatures of preferred embodiments are diagramea in rig. ™™T 

to be determined by reference to the appended claims. 
Claims 

„ 1 A method of preparing and using a mask for incremental printing, using a preestabiished program that incorporates 
complete conditions for a usable mask; said method comprising the steps of : 

of: 

for each pixel position in a mask to be prepared, identifying nearby positions only by • «*^* «T 
era«zed Siat notation that is relative, substantially without reference to absolute posfon ,n the mask. 

win resoect to each nearby position that is thus identified by the generalized notation, expressing in only 
TOSSSS g" era"ed y £p.idt notation the acceptability of inking said pixel porton * particular ,nk- 
drop planes of the mask; and 
men automatical uang the produced mask or storing the produced mask for later use. substantia^ without 
human intervention as to mask content. 

2. A method according to claim 1 , wherein: 

3. The method of claim 1 or 2, wherein: 
the identifying step further includes identtfying nearby positions among successive inkdrop planes. 

4. The method of claim 3, wherein: 
the expressing step further includes expressing in only a substantially generalized ^ "otetion the acsept- 
SitTof inking saS pixe. position with respect to said nearby posfcons among success.ve mkdrop planes. 

5. The method of any preceding claim, wherein at least one said substantial* generalized acceptability notation com- 
prises: 

a M numtrt* «du. reprtsenSng . partcul.. distance N>* i™W**> * «~. «™"- 

particular distance. 

6. The method of claim 5. wherein the second numeric*, value has a significance se.ected from the group consisting 
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a prohibition of inking; 

a relative permissibility of inking; and 
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a relative probability to be applied in determining inking. 

7. The method of claim 6, wherein: 

in some determinations the significance of the second numerical value is determined by a program step that 
selects automatically between the relative permissibility and the relative probability, based upon a desired bal- 
ance between deterministic and random masking. 

The method of any one of claims 1 to 4, wherein the substantially generalized acceptability notation comprises: 

a local grid including a representation of said pixel position and some nearby pixel positions; and 
in at least some positions within the local grid, relative to the pixel under calculation, a numerical representation 
of the permissible or preferable distance to a position where inking may occur. 

75 9. The method of any one of claims 1 to 4, wherein the operating step comprises the substeps of: 

considering candidate pass numbers, for a particular position in the mask, and expressing the favorability of 
each candidate pass number, with regard to each of plural neighboring positions, as a "neighborhood con- 
straint in the form of a respective weight; 

consolidating the weights to obtain a single measure of favorability for each candidate pass number; 
based on the single measure of favorability, choosing one of the candidate pass numbers for use at the partic- 
ular position in the mask; and 

repeating the considering and expressing step, the consolidating step, and the choosing step for each other 
position in the mask. 

10. The method of claim 9, wherein the program-operating step comprises: 

imposing constraints on the acceptability of all entries in the mask being produced; and 
controlling the number of constraints so that adequate degrees of freedom remain to ensure that the program 
30 can find a solution in substantially each attempt. 

1 1 . A method according to any preceding claim, further comprising the steps of: 

automatically selectively applying a first condition that introduces randomness into a mask to be produced; 
35 automatically selectively applying a second condition that introduces determinism into the mask to be pro- 

duced; and 

automatically selecting a balance between the first condition and the second condition to adjust the relative 
degree of randomness and determinism in the printmask to be produced. 

40 12. A method according to any preceding claim, further comprising the steps of: 

for each pixel position in a mask to be prepared, determining a multiplicity of numerical weighting values that 
respectively represent relative acceptability of inking in a particular inkdrop plane with respect to each of a mul- 
tiplicity of operating conditions or other nearby positions; and 
45 consolidating the multiplicity of numerical weighting values to determine substantially a single numerical 

weighting value that represents overall relative acceptability of inking at said pixel position in the particular ink- 
drop plane. 

1 3. A method according to any preceding claim, further comprising the steps of: 

50 

evaluating the potential use of certain print nozzles for inking at a particular pixel position in a mask to be pre- 
pared; and 

taking into account the results of the evaluating step in determining relative acceptability of inking that particu- 
lar pixel position, in a particular inkdrop plane, to prepare the mask. 

55 

14. The method of claim 13, wherein the evaluating step comprises at least one step selected from the group consist- 
ing of: 
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applying a nozzle-usage acceptance value that defines the level of acceptability of each of the certain print 
nozzles, respectively; and 

applying a nozzle-usage distribution value that defines a desired level usage of each of the certain pnnt noz- 
zles, respectively. 

15 A method according to any preceding claim, said method using a self-standing input text file of mask constraints, 
and also using a mask-generating control algorithm; said method further comprising the steps of: 

automatically reading the self-standing input text file to accept such constraints; 

automatically accepting any definition of a mask-generating modular control algorithm that applies said mask 
constraints; 

automatically generating a mask, under control of a printmask-generating modular control algorithm; 
automatically operating the defined mask-generating modular control algorithm to apply the mask constraints 
and thereby control the mask-generating step; and 

automatically forwarding the generated mask for use, or for storage and later use, in a printer or a printer driver 
for operating the printer to print images. 

16 A method according to any preceding claim, said method using a self-standing input text file of mask constraints, 
and also using a mask-optimizing control algorithm; and said method further comprising the steps of: 

reading the self-standing input text file to accept such constraints; 
applying the accepted constraints to generate a mask; 

accepting any definition of a mask-optimizing modular control algorithm that receives said generated mask as 
an input and reprocesses said received mask to substantially optimize it for image quality ; 
operating the accepted mask-optimizing modular control algorithm to reprocess said received mask to sub- 
stantially optimize it for image quality; and 
forwarding the optimized mask for use. or for storage and later use. in a printer or a printer driver for operating 

" the printer to print images. 
30 1 7. The method of any of claims 1 through 4, or any of claims 8 through 22, wherein: 

at least one of said steps is performed with respect to a printmask or a halftoning mask, or both. 

18. An incremental printer comprising storage means in which is stored a mask prepared in accordance with the 
35 method of any preceding claim. 

1 9. An incremental printer, as claimed in claim 1 8, further comprising execution means adapted to execute the method 
steps of any one of claims 1 to 17. 
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